2020-10-26 10:29:30 +00:00
---
2022-04-09 13:29:05 +00:00
sidebar_position: 60
sidebar_label: clickhouse-local
2020-10-26 10:29:30 +00:00
---
2020-03-20 18:20:59 +00:00
# clickhouse-local {#clickhouse-local}
2018-03-02 09:44:48 +00:00
2020-04-09 18:06:07 +00:00
Принимает на вход данные, которые можно представить в табличном виде и выполняет над ними операции, заданные на [языке запросов ](../../operations/utilities/clickhouse-local.md ) ClickHouse.
2018-04-16 05:32:37 +00:00
2018-04-16 12:04:59 +00:00
`clickhouse-local` использует движок сервера ClickHouse, т.е . поддерживает все форматы данных и движки таблиц, с которыми работает ClickHouse, при этом для выполнения операций не требуется запущенный сервер.
2018-04-16 05:32:37 +00:00
2018-04-16 12:04:59 +00:00
`clickhouse-local` при настройке по умолчанию не имеет доступа к данным, которыми управляет сервер ClickHouse, установленный на этом же хосте, однако можно подключить конфигурацию сервера с помощью ключа `--config-file` .
2018-04-16 05:32:37 +00:00
2022-04-09 13:29:05 +00:00
:::danger "Warning"
2018-07-20 17:35:34 +00:00
Мы не рекомендуем подключать серверную конфигурацию к `clickhouse-local` , поскольку данные можно легко повредить неосторожными действиями.
2018-04-16 05:32:37 +00:00
2021-07-29 15:20:55 +00:00
Для временных данных по умолчанию создается специальный каталог.
2020-11-02 16:54:23 +00:00
2021-03-06 11:13:14 +00:00
## Вызов программы {#usage}
2018-04-16 05:32:37 +00:00
Основной формат вызова:
2020-03-20 18:20:59 +00:00
``` bash
2021-01-25 22:39:23 +00:00
$ clickhouse-local --structure "table_structure" --input-format "format_of_incoming_data" \
--query "query"
2018-04-16 05:32:37 +00:00
```
Ключи команды:
2020-03-21 04:11:51 +00:00
- `-S` , `--structure` — структура таблицы, в которую будут помещены входящие данные.
2022-06-20 22:09:55 +00:00
- `--input-format` — формат входящих данных. По умолчанию — `TSV` .
2020-03-21 04:11:51 +00:00
- `-f` , `--file` — путь к файлу с данными. По умолчанию — `stdin` .
- `-q` , `--query` — запросы на выполнение. Разделитель запросов — `;` .
2022-06-20 22:09:55 +00:00
- `--queries-file` - путь к файлу с запросами для выполнения. Необходимо задать либо параметр `query` , либо `queries-file` .
2020-03-21 04:11:51 +00:00
- `-N` , `--table` — имя таблицы, в которую будут помещены входящие данные. По умолчанию - `table` .
2022-06-20 22:09:55 +00:00
- `--format` , `--output-format` — формат выходных данных. По умолчанию — `TSV` .
2021-03-06 11:13:14 +00:00
- `-d` , `--database` — база данных по умолчанию. Если не указано, используется значение `_local` .
2020-03-21 04:11:51 +00:00
- `--stacktrace` — вывод отладочной информации при исключениях.
2021-07-29 15:20:55 +00:00
- `--echo` — перед выполнением запрос выводится в консоль.
2020-03-21 04:11:51 +00:00
- `--verbose` — подробный вывод при выполнении запроса.
2021-03-06 11:13:14 +00:00
- `--logger.console` — логирование действий в консоль.
- `--logger.log` — логирование действий в файл с указанным именем.
- `--logger.level` — уровень логирования.
- `--ignore-error` — не прекращать обработку если запрос выдал ошибку.
2021-03-06 20:27:08 +00:00
- `-c` , `--config-file` — путь к файлу конфигурации. По умолчанию `clickhouse-local` запускается с пустой конфигурацией. Конфигурационный файл имеет тот же формат, что и для сервера ClickHouse, и в нём можно использовать все конфигурационные параметры сервера. Обычно подключение конфигурации не требуется; если требуется установить отдельный параметр, то это можно сделать ключом с именем параметра.
2021-03-06 11:13:14 +00:00
- `--no-system-tables` — запуск без использования системных таблиц.
2020-03-21 04:11:51 +00:00
- `--help` — вывод справочной информации о `clickhouse-local` .
2021-03-06 11:13:14 +00:00
- `-V` , `--version` — вывод текущей версии и выход.
2018-04-16 05:32:37 +00:00
2021-03-06 11:13:14 +00:00
## Примеры вызова {#examples}
2018-04-16 05:32:37 +00:00
2020-03-20 18:20:59 +00:00
``` bash
2020-11-02 16:54:23 +00:00
$ echo -e "1,2\n3,4" | clickhouse-local --structure "a Int64, b Int64" \
--input-format "CSV" --query "SELECT * FROM table"
2018-04-16 05:32:37 +00:00
Read 2 rows, 32.00 B in 0.000 sec., 5182 rows/sec., 80.97 KiB/sec.
2020-11-02 16:54:23 +00:00
1 2
3 4
2018-04-16 05:32:37 +00:00
```
Вызов выше эквивалентен следующему:
2020-03-20 18:20:59 +00:00
``` bash
2020-11-02 16:54:23 +00:00
$ echo -e "1,2\n3,4" | clickhouse-local --query "
CREATE TABLE table (a Int64, b Int64) ENGINE = File(CSV, stdin);
SELECT a, b FROM table;
DROP TABLE table"
2018-04-16 05:32:37 +00:00
Read 2 rows, 32.00 B in 0.000 sec., 4987 rows/sec., 77.93 KiB/sec.
2020-11-02 16:54:23 +00:00
1 2
3 4
```
Необязательно использовать ключи `stdin` или `--file` . Вы можете открывать любое количество файлов с помощью [табличной функции `file` ](../../sql-reference/table-functions/file.md ):
``` bash
$ echo 1 | tee 1.tsv
1
$ echo 2 | tee 2.tsv
2
$ clickhouse-local --query "
select * from file('1.tsv', TSV, 'a int') t1
cross join file('2.tsv', TSV, 'b int') t2"
1 2
2018-04-16 05:32:37 +00:00
```
2021-02-15 18:25:31 +00:00
Объём оперативной памяти, занимаемой процессами, которые запустил пользователь (Unix):
2018-04-16 05:32:37 +00:00
2021-01-25 22:39:23 +00:00
Запрос:
2020-03-20 18:20:59 +00:00
``` bash
2020-11-02 16:54:23 +00:00
$ ps aux | tail -n +2 | awk '{ printf("%s\t%s\n", $1, $4) }' \
| clickhouse-local --structure "user String, mem Float64" \
--query "SELECT user, round(sum(mem), 2) as memTotal
FROM table GROUP BY user ORDER BY memTotal DESC FORMAT Pretty"
```
2021-02-01 18:11:47 +00:00
Результат:
2021-01-25 22:39:23 +00:00
2020-11-02 16:54:23 +00:00
``` text
2018-04-16 05:32:37 +00:00
Read 186 rows, 4.15 KiB in 0.035 sec., 5302 rows/sec., 118.34 KiB/sec.
┏━━━━━━━━━━┳━━━━━━━━━━┓
┃ user ┃ memTotal ┃
┡━━━━━━━━━━╇━━━━━━━━━━┩
│ bayonet │ 113.5 │
├──────────┼──────────┤
│ root │ 8.8 │
├──────────┼──────────┤
...
```