Утилита clickhouse-format
Позволяет форматировать входные запросы.
Ключи:
--help или -h — Вывести справочное сообщение.
--query — Форматировать запросы любой длины и сложности.
--hilite — Добавить подсветку синтаксиса с помощью управляющих последовательностей ANSI терминала.
--oneline — Форматировать в одну строку.
--max_line_length — Форматировать в одной строке запросы длиной меньше указанной.
--comments — Сохранять комментарии в выводе.
--quiet или -q — Просто проверить синтаксис, без вывода при успехе.
--multiquery или -n — Разрешить несколько запросов в одном файле.
--obfuscate — Обфусцировать вместо форматирования.
--seed <string> — Случайная строка, которая определяет результат обфускации.
--backslash — Добавить обратный слэш в конце каждой строки форматированного запроса. Может быть полезно, когда вы копируете запрос из интернета или откуда-либо еще с несколькими строками и хотите выполнить его в командной строке.
Примеры
- Форматирование запроса:
$ clickhouse-format --query "select number from numbers(10) where number%2 order by number desc;"
Результат:
SELECT number
FROM numbers(10)
WHERE number % 2
ORDER BY number DESC
- Подсветка и одна строка:
$ clickhouse-format --oneline --hilite <<< "SELECT sum(number) FROM numbers(5);"
Результат:
SELECT sum(number) FROM numbers(5)
- Мульти-запросы:
$ clickhouse-format -n <<< "SELECT min(number) FROM numbers(5); SELECT max(number) FROM numbers(5);"
Результат:
SELECT min(number)
FROM numbers(5)
;
SELECT max(number)
FROM numbers(5)
;
- Обфускация:
$ clickhouse-format --seed Hello --obfuscate <<< "SELECT cost_first_screen BETWEEN a AND b, CASE WHEN x >= 123 THEN y ELSE NULL END;"
Результат:
SELECT treasury_mammoth_hazelnut BETWEEN nutmeg AND span, CASE WHEN chive >= 116 THEN switching ELSE ANYTHING END;
Тот же запрос и другая строка семени:
$ clickhouse-format --seed World --obfuscate <<< "SELECT cost_first_screen BETWEEN a AND b, CASE WHEN x >= 123 THEN y ELSE NULL END;"
Результат:
SELECT horse_tape_summer BETWEEN folklore AND moccasins, CASE WHEN intestine >= 116 THEN nonconformist ELSE FORESTRY END;
- Добавление обратного слэша:
$ clickhouse-format --backslash <<< "SELECT * FROM (SELECT 1 AS x UNION ALL SELECT 1 UNION DISTINCT SELECT 3);"
Результат:
SELECT * \
FROM \
( \
SELECT 1 AS x \
UNION ALL \
SELECT 1 \
UNION DISTINCT \
SELECT 3 \
)