Движок таблицы ODBC
Позволяет ClickHouse подключаться к внешним базам данных через ODBC.
Для безопасной организации ODBC-подключений ClickHouse использует отдельную программу clickhouse-odbc-bridge. Если ODBC-драйвер загружается непосредственно из clickhouse-server, проблемы в драйвере могут привести к сбою сервера ClickHouse. ClickHouse автоматически запускает clickhouse-odbc-bridge, когда это требуется. Программа моста ODBC устанавливается из того же пакета, что и 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 Server 5.7.
Убедитесь, что установлены unixODBC и MySQL Connector.
По умолчанию (при установке из пакетов) ClickHouse запускается от имени пользователя clickhouse. Поэтому вам необходимо создать и настроить этого пользователя на сервере MySQL.
Затем настройте подключение в /etc/odbc.ini.
Вы можете проверить соединение с помощью утилиты isql, входящей в состав unixODBC.
Таблица в MySQL:
Таблица в ClickHouse, которая получает данные из таблицы MySQL: