genfay / laravel-clickhouse
Installs: 9
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 102
pkg:composer/genfay/laravel-clickhouse
Requires
- php: >=7.0
- laravel/framework: 5.5.*
- the-tinderbox/clickhouse-builder: ~1.0
Requires (Dev)
- fzaninotto/faker: ~1.4
- mockery/mockery: 0.9.*
- phpunit/phpunit: ~6.0
This package is auto-updated.
Last update: 2025-10-26 05:11:11 UTC
README
Eloquent model for ClickHouse
Prerequisites
- php 7.1
- clickhouse server
Installation
$ composer require genfay/laravel-clickhouse
Then add the code above into your config/app.php file providers section
Genfay\LaravelClickHouse\ClickHouseServiceProvider::class,
And add new connection into your config/database.php file. Something like this:
'connections' => [ 'clickhouse' => [ 'driver' => 'clickhouse', 'host' => '', 'port' => '', 'database' => '', 'username' => '', 'password' => '', 'options' => [ 'timeout' => 10, 'protocol' => 'https' ] ] ]
Or like this, if clickhouse runs in cluster
'connections' => [ 'clickhouse' => [ 'driver' => 'clickhouse', 'cluster' => [ 'server-1' => [ 'host' => '', 'port' => '', 'database' => '', 'username' => '', 'password' => '', 'options' => [ 'timeout' => 10, 'protocol' => 'https' ] ], 'server-2' => [ 'host' => '', 'port' => '', 'database' => '', 'username' => '', 'password' => '', 'options' => [ 'timeout' => 10, 'protocol' => 'https' ] ] ] ] ]
Then create model
<?php use Genfay\LaravelClickHouse\Database\Eloquent\Model; class Payment extends Model { protected $table = 'payments'; }
And use it
Payment::select(raw('count() AS cnt'), 'payment_system') ->whereBetween('payed_at', [ Carbon\Carbon::parse('2017-01-01'), now(), ]) ->groupBy('payment_system') ->get();
Roadmap
- more tests
- Model::with() method
- relations