MySQL

Движок MySQL позволяет выполнять SELECT запросы над данными, хранящимися на удалённом MySQL сервере.

Формат вызова:

MySQL('host:port', 'database', 'table', 'user', 'password'[, replace_query, 'on_duplicate_clause']);

Параметры вызова

  • host:port — Адрес сервера MySQL.
  • database — Имя базы данных на сервере MySQL.
  • table — Имя таблицы.
  • user — Пользователь MySQL.
  • password — Пароль пользователя.
  • replace_query — Флаг, устанавливающий замену запроса INSERT INTO на REPLACE INTO. Если replace_query=1, то запрос заменяется.
  • on_duplicate_clause — Добавляет выражение ON DUPLICATE KEY 'on_duplicate_clause' в запрос INSERT.

    Например, INSERT INTO t (c1,c2) VALUES ('a', 2) ON DUPLICATE KEY UPDATE c2 = c2 + 1, где on_duplicate_clauseUPDATE c2 = c2 + 1. Какие выражения on_duplicate_clause вы можете использовать с ON DUPLICATE KEY, смотрите в документации MySQL.

    Чтобы указать on_duplicate_clause необходимо передать 0 в параметр replace_query. Если одновременно передать replace_query = 1 и on_duplicate_clause, то ClickHouse сгенерирует исключение.

На данный момент простые условия WHERE, такие как =, !=, >, >=, <, <= будут выполняться на стороне сервера MySQL.

Остальные условия и ограничение выборки LIMIT будут выполнены в ClickHouse только после выполнения запроса к MySQL.

Движок MySQL не поддерживает тип данных Nullable, поэтому при чтении данных из таблиц MySQL NULL преобразуются в значения по умолчанию для заданного типа столбца, обычно это 0 или пустая строка.