smi2/phpclickhouse

PHP ClickHouse Client

Maintainers

Package info

github.com/smi2/phpClickHouse

pkg:composer/smi2/phpclickhouse

Statistics

Installs: 10 193 892

Dependents: 79

Suggesters: 1

Stars: 834

Open Issues: 1

1.26.4 2026-04-04 10:39 UTC

README

Downloads Packagist Licence

Documentation Site

PHP client for ClickHouse — fast, lightweight, no dependencies beyond ext-curl.

Features

Requirements

  • PHP 8.0+
  • ext-curl
  • ext-json

Version compatibility:

PHP phpClickHouse
5.6 <= 1.1.2
7.2 <= 1.3.10
7.3 1.4.x – 1.5.x
8.0+ >= 1.6.0

Installation

composer require smi2/phpclickhouse

Quick Start

$db = new ClickHouseDB\Client([
    'host'     => '127.0.0.1',
    'port'     => '8123',
    'username' => 'default',
    'password' => '',
]);

$db->database('default');
$db->setTimeout(10);
$db->setConnectTimeOut(5);
$db->ping(true); // throws exception on failure

Select

$statement = $db->select('SELECT * FROM my_table WHERE id = :id', ['id' => 42]);

$statement->rows();      // all rows
$statement->fetchOne();  // first row
$statement->count();     // row count

Native Query Parameters

// Server-side typed binding — SQL injection impossible at protocol level
$result = $db->selectWithParams(
    'SELECT * FROM users WHERE id = {id:UInt32} AND name = {name:String}',
    ['id' => 42, 'name' => 'Alice']
);

Insert

$db->insert('my_table',
    [
        [time(), 'key1', 100],
        [time(), 'key2', 200],
    ],
    ['event_time', 'key', 'value']
);

Generator (large resultsets)

// Memory-efficient — one row at a time, no OOM
foreach ($db->selectGenerator('SELECT * FROM huge_table') as $row) {
    processRow($row);
}

Write (DDL)

$db->write('CREATE TABLE IF NOT EXISTS my_table (id UInt32, name String) ENGINE = MergeTree ORDER BY id');
$db->write('DROP TABLE IF EXISTS my_table');

Documentation

Detailed guides with examples are available in the doc/ directory:

Core

Advanced

Reference

Development

# Start both ClickHouse versions (21.9 + 26.3)
docker-compose -f tests/docker-compose.yaml up -d

# Run tests against ClickHouse 21.9
./vendor/bin/phpunit -c phpunit-ch21.xml

# Run tests against ClickHouse 26.3
./vendor/bin/phpunit -c phpunit-ch26.xml

# Static analysis (PHPStan level 5)
./vendor/bin/phpstan analyse --memory-limit=512M

# Code style
./vendor/bin/phpcs

See CLAUDE.md for project architecture and contribution guidelines.

Articles

License

MIT — see LICENSE

Changelog

See CHANGELOG.md