Клиент ClickHouse
client-v2. У него понятный API, более легковесная кодовая база, заметно улучшенная производительность и более качественная поддержка форматов ClickHouse (главным образом RowBinary и Native). В ближайшем будущем JDBC будет использовать этот клиент.
Поддерживаемые типы данных
| Тип данных | Поддержка в клиенте V2 | Поддержка в клиенте V1 |
|---|---|---|
| Int8 | ✔ | ✔ |
| Int16 | ✔ | ✔ |
| Int32 | ✔ | ✔ |
| Int64 | ✔ | ✔ |
| Int128 | ✔ | ✔ |
| Int256 | ✔ | ✔ |
| UInt8 | ✔ | ✔ |
| UInt16 | ✔ | ✔ |
| UInt32 | ✔ | ✔ |
| UInt64 | ✔ | ✔ |
| UInt128 | ✔ | ✔ |
| UInt256 | ✔ | ✔ |
| Float32 | ✔ | ✔ |
| Float64 | ✔ | ✔ |
| Decimal | ✔ | ✔ |
| Decimal32 | ✔ | ✔ |
| Decimal64 | ✔ | ✔ |
| Decimal128 | ✔ | ✔ |
| Decimal256 | ✔ | ✔ |
| Bool | ✔ | ✔ |
| String | ✔ | ✔ |
| FixedString | ✔ | ✔ |
| Nullable | ✔ | ✔ |
| Date | ✔ | ✔ |
| Date32 | ✔ | ✔ |
| DateTime | ✔ | ✔ |
| DateTime32 | ✔ | ✔ |
| DateTime64 | ✔ | ✔ |
| Interval | ✗ | ✗ |
| Enum | ✔ | ✔ |
| Enum8 | ✔ | ✔ |
| Enum16 | ✔ | ✔ |
| Array | ✔ | ✔ |
| Map | ✔ | ✔ |
| Nested | ✔ | ✔ |
| Tuple | ✔ | ✔ |
| UUID | ✔ | ✔ |
| IPv4 | ✔ | ✔ |
| IPv6 | ✔ | ✔ |
| Object | ✗ | ✔ |
| Point | ✔ | ✔ |
| Nothing | ✔ | ✔ |
| MultiPolygon | ✔ | ✔ |
| Ring | ✔ | ✔ |
| Polygon | ✔ | ✔ |
| SimpleAggregateFunction | ✔ | ✔ |
| AggregateFunction* | ✔ | ✔ |
| Variant | ✔ | ✗ |
| Dynamic | ✔ | ✗ |
| JSON | ✔ | ✗ |
Частичная поддержка
- AggregateFunction — Для прямого чтения в бинарном формате поддерживается только
groupBitmap. Для других агрегатных функций (min,max,avgи т. д.) используйте комбинаторы-Mergeв запросе (например,minMerge(),avgMerge()), чтобы вычислить состояние на стороне сервера.SELECT * FROM table ...не поддерживается для столбцов типаAggregateFunction.
Примечания по типам данных
- Decimal —
SET output_format_decimal_trailing_zeros=1в 21.9+ для единообразия. - Enum — может обрабатываться как строка и как целое число.
- UInt64 — в client-v1 сопоставляется с
long.
Возможности
| Имя | Client V2 | Client V1 | Комментарии |
|---|---|---|---|
| HTTP-соединение | ✔ | ✔ | |
| HTTP-сжатие (LZ4) | ✔ | ✔ | |
| Сжатие под управлением приложения | ✔ | ✗ | |
| Сжатие ответа сервера — LZ4 | ✔ | ✔ | |
| Сжатие запроса клиента — LZ4 | ✔ | ✔ | |
| HTTPS | ✔ | ✔ | |
| Клиентский SSL-сертификат (mTLS) | ✔ | ✔ | |
| HTTP-прокси | ✔ | ✔ | |
| POJO SerDe | ✔ | ✗ | |
| Пул соединений | ✔ | ✔ | При использовании Apache HTTP Client |
| Именованные параметры | ✔ | ✔ | |
| Повтор при сбое | ✔ | ✔ | |
| Аварийное переключение | ✗ | ✔ | |
| Балансировка нагрузки | ✗ | ✔ | |
| Автообнаружение сервера | ✗ | ✔ | |
| Комментарий Log | ✔ | ✔ | |
| Роли сеанса | ✔ | ✔ | |
| SSL-аутентификация клиента | ✔ | ✔ | |
| Конфигурация SNI | ✔ | ✗ | |
| Часовой пояс сеанса | ✔ | ✔ |
Совместимость
- Все проекты в этом репозитории тестируются со всеми актуальными LTS-версиями ClickHouse.
- Политика поддержки
- Мы рекомендуем регулярно обновлять клиент, чтобы не пропускать исправления безопасности и новые улучшения
- Если у вас возникли проблемы при миграции на API v2, создайте issue, и мы ответим!
Логирование
Logback или Log4j.
Например, если вы используете Maven, можно добавить в файл pom.xml следующую зависимость:
pom.xml
Настройка логирования
Logback, логирование можно настроить в файле logback.xml:
logback.xml