2021-04-25 06:58:57 +00:00
---
toc_priority: 65
toc_title: clickhouse-format
---
# clickhouse-format {#clickhouse-format}
2021-04-29 03:27:21 +00:00
Позволяет форматировать входящие запросы.
2021-04-25 06:58:57 +00:00
Ключи:
2021-04-29 03:28:00 +00:00
- `--help` или`-h` — выводит описание ключей.
- `--hilite` — добавляет подсветку синтаксиса с экранированием символов.
- `--oneline` — форматирование в одну строку.
- `--quiet` или `-q` — проверяет синтаксис без вывода результата.
- `--multiquery` or `-n` — поддерживает несколько запросов в одной строке.
2021-05-12 12:15:02 +00:00
- `--obfuscate` — обфусцирует вместо форматирования.
2021-04-29 03:28:00 +00:00
- `--seed <строка>` — задает строку, которая определяет результат обфускации.
2021-05-12 12:11:44 +00:00
- `--backslash` — добавляет обратный слеш в конце каждой строки отформатированного запроса. Удобно использовать если многострочный запрос скопирован из интернета или другого источника и е г о нужно выполнить из командной строки.
2021-04-25 06:58:57 +00:00
2021-07-29 15:20:55 +00:00
## Примеры {#examples}
2021-04-25 06:58:57 +00:00
2021-04-29 03:27:21 +00:00
1. Подсветка синтаксиса и форматирование в одну строку:
2021-04-25 06:58:57 +00:00
2021-04-25 07:21:46 +00:00
```bash
2021-04-25 08:47:05 +00:00
$ clickhouse-format --oneline --hilite < < < "SELECT sum(number) FROM numbers(5);"
2021-04-25 07:21:46 +00:00
```
2021-04-25 06:58:57 +00:00
2021-04-25 07:21:46 +00:00
Результат:
2021-04-25 06:58:57 +00:00
2021-04-25 07:21:46 +00:00
```sql
SELECT sum(number) FROM numbers(5)
```
2021-04-25 06:58:57 +00:00
2021-07-29 15:20:55 +00:00
2. Несколько запросов в одной строке:
2021-04-25 06:58:57 +00:00
2021-04-25 07:21:46 +00:00
```bash
2021-04-25 08:47:05 +00:00
$ clickhouse-format -n < < < "SELECT * FROM (SELECT 1 AS x UNION ALL SELECT 1 UNION DISTINCT SELECT 3);"
2021-04-25 07:21:46 +00:00
```
2021-07-29 15:20:55 +00:00
2021-04-25 07:21:46 +00:00
Результат:
2021-04-25 06:58:57 +00:00
2021-04-25 07:21:46 +00:00
```text
2021-05-14 16:22:54 +00:00
SELECT *
FROM
2021-04-25 07:21:46 +00:00
(
2021-05-14 16:22:54 +00:00
SELECT 1 AS x
UNION ALL
2021-04-25 06:58:57 +00:00
SELECT 1
2021-04-25 07:21:46 +00:00
UNION DISTINCT
SELECT 3
)
;
```
2021-05-12 12:11:44 +00:00
3. Обфускация:
2021-04-25 06:58:57 +00:00
2021-04-25 07:21:46 +00:00
```bash
2021-04-25 08:47:05 +00:00
$ clickhouse-format --seed Hello --obfuscate < < < "SELECT cost_first_screen BETWEEN a AND b, CASE WHEN x >= 123 THEN y ELSE NULL END;"
2021-04-25 07:21:46 +00:00
```
Результат:
2021-04-25 07:09:43 +00:00
2021-04-25 07:21:46 +00:00
```text
SELECT treasury_mammoth_hazelnut BETWEEN nutmeg AND span, CASE WHEN chive >= 116 THEN switching ELSE ANYTHING END;
```
2021-07-29 15:20:55 +00:00
2021-05-12 12:11:44 +00:00
Тот же запрос с другой инициализацией обфускатора:
2021-04-25 06:58:57 +00:00
2021-04-25 07:21:46 +00:00
```bash
$ clickhouse-format --seed World --obfuscate < < < "SELECT cost_first_screen BETWEEN a AND b, CASE WHEN x >= 123 THEN y ELSE NULL END;"
```
2021-07-29 15:20:55 +00:00
2021-04-25 07:21:46 +00:00
Результат:
2021-04-25 06:58:57 +00:00
2021-04-25 07:21:46 +00:00
```text
SELECT horse_tape_summer BETWEEN folklore AND moccasins, CASE WHEN intestine >= 116 THEN nonconformist ELSE FORESTRY END;
```
2021-04-25 06:58:57 +00:00
2021-04-29 03:27:21 +00:00
4. Добавление обратного слеша:
2021-04-25 06:58:57 +00:00
2021-04-25 07:21:46 +00:00
```bash
2021-04-25 08:47:05 +00:00
$ clickhouse-format --backslash < < < "SELECT * FROM (SELECT 1 AS x UNION ALL SELECT 1 UNION DISTINCT SELECT 3);"
2021-04-25 07:21:46 +00:00
```
Результат:
```text
SELECT * \
FROM \
( \
SELECT 1 AS x \
UNION ALL \
SELECT 1 \
UNION DISTINCT \
SELECT 3 \
)
2021-07-29 15:20:55 +00:00
```