odbc
Позволяет ClickHouse подключаться к внешним базам данных через ODBC.
Для безопасной реализации ODBC-соединений ClickHouse использует отдельную программу clickhouse-odbc-bridge
. Если ODBC-драйвер загружается непосредственно из clickhouse-server
, проблемы с драйвером могут привести к сбоям сервера ClickHouse. ClickHouse автоматически запускает clickhouse-odbc-bridge
, когда это требуется. Программа ODBC bridge устанавливается из того же пакета, что и clickhouse-server
.
Этот движок поддерживает тип данных Nullable.
Создание таблицы
Смотрите подробное описание запроса CREATE TABLE.
Структура таблицы может отличаться от структуры исходной таблицы:
- Имена колонок должны совпадать с именами в исходной таблице, но вы можете использовать только некоторые из этих колонок и в любом порядке.
- Типы колонок могут отличаться от таковых в исходной таблице. ClickHouse пытается привести значения к типам данных ClickHouse.
- Параметр external_table_functions_use_nulls определяет, как обрабатывать Nullable-колонки. Значение по умолчанию: 1. Если 0, табличная функция не создает Nullable-колонки и вставляет значения по умолчанию вместо null. Это также применимо к значениям NULL внутри массивов.
Параметры движка
datasource
— Имя секции с настройками соединения в файлеodbc.ini
.external_database
— Имя базы данных во внешней СУБД.external_table
— Имя таблицы вexternal_database
.
Эти параметры также могут быть переданы с помощью именованных коллекций.
Пример использования
Получение данных из локальной установки MySQL через ODBC
Этот пример проверялся на Ubuntu Linux 18.04 и MySQL сервере 5.7.
Убедитесь, что установлены unixODBC и MySQL Connector.
По умолчанию (если установлено из пакетов) ClickHouse запускается от имени пользователя clickhouse
. Таким образом, вам необходимо создать и настроить этого пользователя на сервере MySQL.
Затем настройте соединение в /etc/odbc.ini
.
Вы можете проверить соединение с помощью утилиты isql
из установки unixODBC.
Таблица в MySQL:
Таблица в ClickHouse, получающая данные из таблицы MySQL: