설치
실행
ClickHouse를 다운로드만 하고 설치하지 않았다면
clickhouse-client 대신 ./clickhouse client를 사용하세요.| 옵션 | 설명 |
|---|---|
--port <port> | ClickHouse 서버가 연결을 수신하는 포트입니다. 기본 포트는 9440(TLS) 및 9000(TLS 미사용)입니다. ClickHouse Client는 HTTP(S)가 아니라 네이티브 프로토콜을 사용한다는 점에 유의하십시오. |
-s [ --secure ] | TLS를 사용할지 여부입니다(대개 자동으로 감지됩니다). |
-u [ --user ] <username> | 연결할 때 사용할 데이터베이스 사용자입니다. 기본적으로 default 사용자로 연결됩니다. |
--password <password> | 데이터베이스 사용자의 비밀번호입니다. 연결에 사용할 비밀번호는 설정 파일에서 지정할 수도 있습니다. 비밀번호를 지정하지 않으면 클라이언트가 입력을 요청합니다. |
-c [ --config ] <path-to-file> | ClickHouse Client의 설정 파일이 기본 위치 중 하나에 없을 경우 해당 설정 파일의 위치입니다. 설정 파일을 참조하십시오. |
--connection <name> | 설정 파일에 미리 구성된 연결 정보의 이름입니다. |
ClickHouse Cloud에 연결하기
Native를 선택하면 예시
clickhouse-client 명령과 함께 연결 세부 정보가 표시됩니다:
설정 파일에 연결 정보 저장하기
쿼리 구문에 집중하기 위해 나머지 예시에서는 접속 정보(
--host, --port 등)를 생략합니다. 명령을 사용할 때는 이를 추가하십시오.대화형 모드
대화형 모드 사용하기
PrettyCompact입니다.
쿼리의 FORMAT 절에서 포맷을 변경하거나 --format 명령줄 옵션을 지정할 수 있습니다.
Vertical 형식을 사용하려면 --vertical을 사용하거나 쿼리 끝에 \G를 지정할 수 있습니다.
이 형식에서는 각 값이 별도의 줄에 출력되므로 열이 많은 테이블에 편리합니다.
대화형 모드에서는 기본적으로 Enter를 누르면 입력한 내용이 실행됩니다.
쿼리 끝에 세미콜론은 필요하지 않습니다.
-m, --multiline 매개변수로 클라이언트를 시작할 수 있습니다.
여러 줄 쿼리를 입력하려면 줄 바꿈 앞에 백슬래시 \를 입력하십시오.
Enter를 누르면 쿼리의 다음 줄을 입력하라는 메시지가 표시됩니다.
쿼리를 실행하려면 끝에 세미콜론을 붙인 뒤 Enter를 누르십시오.
ClickHouse Client는 replxx(readline과 유사)를 기반으로 하므로 익숙한 키보드 단축키를 사용할 수 있으며 이력을 유지합니다.
이력은 기본적으로 ~/.clickhouse-client-history에 기록됩니다.
클라이언트를 종료하려면 Ctrl+D를 누르거나, 쿼리 대신 다음 중 하나를 입력하십시오.
exit또는exit;quit또는quit;q,Q또는:qlogout또는logout;
쿼리 처리 정보
- 진행 상황으로, 기본적으로 초당 10회를 넘지 않도록 갱신됩니다. 쿼리가 매우 빠르면 진행 상황이 표시되기 전에 처리가 끝날 수 있습니다.
- 디버깅을 위한 구문 분석 후의 포맷팅된 쿼리.
- 지정된 포맷의 결과.
- 결과의 행 수, 경과 시간, 쿼리 처리의 평균 속도. 모든 데이터 양은 비압축 데이터를 기준으로 합니다.
Ctrl+C를 눌러 취소할 수 있습니다.
하지만 server가 요청을 중단할 때까지는 잠시 기다려야 합니다.
특정 단계에서는 쿼리를 취소할 수 없습니다.
기다리지 않고 Ctrl+C를 한 번 더 누르면 클라이언트가 종료됩니다.
ClickHouse Client는 쿼리에 사용할 외부 데이터(외부 임시 테이블)를 전달할 수 있습니다.
자세한 내용은 쿼리 처리용 외부 데이터 섹션을 참조하십시오.
별칭
\l- SHOW DATABASES\d- SHOW TABLES\c <DATABASE>- USE DATABASE.- 마지막 쿼리 다시 실행
키보드 단축키
Alt (Option) + Shift + e- 현재 쿼리로 편집기를 엽니다. 환경 변수EDITOR를 사용해 편집기를 지정할 수 있습니다. 기본 편집기는vim입니다.Alt (Option) + #- 현재 줄을 주석 처리합니다.Ctrl + r- 퍼지 이력 검색을 수행합니다.
배치 모드
배치 모드 사용하기
--query 명령줄 옵션을 사용할 수도 있습니다:
stdin을 통해 쿼리를 제공할 수 있습니다:
messages 테이블이 존재한다고 가정하면, 명령줄에서도 데이터를 삽입할 수 있습니다:
--query를 지정하면 모든 입력이 개행 문자 뒤에 요청에 추가됩니다.
원격 ClickHouse 서비스에 CSV 파일 삽입하기
cell_towers.csv를 default 데이터베이스의 기존 테이블 cell_towers에 삽입합니다:
명령줄에서 데이터를 삽입하는 예시
cat <<_EOF는 heredoc을 시작하며, _EOF가 다시 나타날 때까지 모든 내용을 읽은 다음 출력합니다:
cat을 사용해 file.csv의 내용을 stdout으로 출력한 다음, 이를 파이프로 clickhouse-client의 입력으로 전달합니다:
TabSeparated입니다.
위 예시와 같이 쿼리의 FORMAT 절에서 포맷을 설정할 수 있습니다.
매개변수가 있는 쿼리
쿼리 구문
예시
AI SQL 생성
OPENAI_API_KEY 또는 ANTHROPIC_API_KEY 환경 변수가 설정되어 있으면 AI 지원 기능은 별도 설정 없이 바로 사용할 수 있습니다. 더 고급 구성이 필요하면 구성 섹션을 참조하십시오.
사용 방법
??를 붙이십시오:
- 데이터베이스 스키마를 자동으로 파악합니다
- 파악된 테이블과 컬럼을 바탕으로 적절한 SQL을 생성합니다
- 생성된 쿼리를 즉시 실행합니다
예시
구성
환경 변수 기반 폴백
- 먼저
OPENAI_API_KEY환경 변수를 확인합니다 - 없으면
ANTHROPIC_API_KEY환경 변수를 확인합니다 - 둘 다 없으면 AI 기능이 비활성화됩니다
설정 파일
$XDG_CONFIG_HOME/clickhouse/config.xml(XDG_CONFIG_HOME이 설정되지 않은 경우~/.config/clickhouse/config.xml) (XML 포맷)$XDG_CONFIG_HOME/clickhouse/config.yaml(XDG_CONFIG_HOME이 설정되지 않은 경우~/.config/clickhouse/config.yaml) (YAML 포맷)~/.clickhouse-client/config.xml(XML 포맷, 레거시 위치)~/.clickhouse-client/config.yaml(YAML 포맷, 레거시 위치)- 또는
--config-file로 사용자 지정 경로를 지정하십시오
- XML
- YAML
OpenAI 호환 API 사용(예: OpenRouter):
매개변수
필수 매개변수
필수 매개변수
api_key- AI 서비스용 API Key입니다. 환경 변수로 설정되어 있으면 생략할 수 있습니다:- OpenAI:
OPENAI_API_KEY - Anthropic:
ANTHROPIC_API_KEY - 참고: 구성 파일의 API Key가 환경 변수보다 우선 적용됩니다
- OpenAI:
provider- AI 프로바이더입니다:openai또는anthropic- 생략하면 사용 가능한 환경 변수를 기준으로 자동 폴백이 사용됩니다
모델 구성
모델 구성
model- 사용할 모델입니다(기본값: 프로바이더별 기본값)- OpenAI:
gpt-4o,gpt-4,gpt-3.5-turbo등 - Anthropic:
claude-3-5-sonnet-20241022,claude-3-opus-20240229등 - OpenRouter:
anthropic/claude-3.5-sonnet과 같은 모델 이름을 사용합니다
- OpenAI:
연결 설정
연결 설정
base_url- OpenAI 호환 서비스용 사용자 지정 API 엔드포인트입니다(선택 사항)timeout_seconds- 요청 타임아웃 시간(초)입니다(기본값:30)
스키마 탐색
스키마 탐색
enable_schema_access- AI가 데이터베이스 스키마를 탐색할 수 있도록 허용합니다(기본값:true)max_steps- 스키마 탐색을 위한 도구 호출의 최대 단계 수입니다(기본값:10)
생성 매개변수
생성 매개변수
temperature- 무작위성을 제어합니다. 0.0 = deterministic, 1.0 = 창의적(기본값:0.0)max_tokens- tokens 기준 최대 응답 길이입니다(기본값:1000)system_prompt- AI에 전달할 사용자 지정 지침입니다(선택 사항)
작동 방식
- 스키마 검색
- 사용 가능한 데이터베이스를 나열합니다
- 관련 데이터베이스 내의 테이블을 찾아냅니다
CREATE TABLESQL 문을 통해 테이블 구조를 확인합니다
- 쿼리 생성
- 자연어로 표현한 의도에 맞습니다
- 올바른 테이블 및 컬럼 이름을 사용합니다
- 적절한 조인과 집계를 적용합니다
- 실행
제한 사항
- 활성 인터넷 연결이 필요합니다
- API 사용에는 AI 프로바이더의 속도 제한 및 비용이 적용됩니다
- 복잡한 쿼리는 여러 차례에 걸쳐 수정해야 할 수 있습니다
- AI는 실제 데이터가 아니라 스키마 정보에만 읽기 전용으로 액세스할 수 있습니다
보안
- API keys는 ClickHouse 서버로 전송되지 않습니다
- AI는 실제 데이터가 아니라 스키마 정보(테이블/컬럼 이름 및 타입)만 봅니다
- 생성된 모든 쿼리는 기존 데이터베이스 권한을 준수합니다
연결 문자열
사용법
| 구성 요소(모두 선택 사항) | 설명 | 기본값 |
|---|---|---|
user | 데이터베이스 사용자 이름입니다. | default |
password | 데이터베이스 사용자 비밀번호입니다. :가 지정되어 있고 비밀번호가 비어 있으면 클라이언트가 사용자 비밀번호 입력을 요청합니다. | - |
hosts_and_ports | 호스트와 선택적 포트 목록 host[:port] [, host:[port]], ...입니다. | localhost:9000 |
database | 데이터베이스 이름입니다. | default |
query_parameters | key-value 쌍 목록 param1=value1[,¶m2=value2], ...입니다. 일부 매개변수는 값이 필요하지 않습니다. 매개변수 이름과 값은 대소문자를 구분합니다. | - |
참고 사항
--user, --password 또는 --database로는 지정할 수 없습니다(그 반대도 마찬가지입니다).
host component에는 호스트명 또는 IPv4/IPv6 주소를 사용할 수 있습니다.
IPv6 주소는 []로 감싸야 합니다:
clickHouse-client의 첫 번째 인수로 지정해야 합니다.
연결 문자열은 --host 및 --port를 제외한 다른 명령줄 옵션과 원하는 만큼 함께 사용할 수 있습니다.
query_parameters에는 다음 키를 사용할 수 있습니다:
| Key | Description |
|---|---|
secure (or s) | 지정하면 클라이언트는 보안 연결(TLS)을 통해 서버에 연결합니다. 명령줄 옵션의 --secure를 참조하십시오. |
userpasswordhostsdatabasequery parameters
예시
localhost의 9000번 포트에 연결하여 쿼리 SELECT 1을 실행합니다.
localhost에 사용자 john, 비밀번호 secret, 호스트 127.0.0.1, 포트 9000을 사용해 연결합니다
default 사용자로, IPV6 주소 [::1] 및 포트 9000을 사용하는 localhost 호스트에 연결합니다.
localhost에 연결합니다.
default 사용자로 포트 9000을 사용해 localhost에 연결합니다.
localhost의 9000 포트에 연결하고 기본 데이터베이스는 my_database를 사용합니다.
localhost의 9000번 포트에 연결하고, 연결 문자열에 지정된 my_database 데이터베이스를 기본 데이터베이스로 사용하며, 축약형 s 매개변수로 보안 연결을 사용합니다.
my_user 사용자로 비밀번호 없이 연결합니다.
localhost에 연결합니다. @ 기호는 %40으로 퍼센트 인코딩됩니다.
192.168.1.15, 192.168.1.25.
쿼리 ID 형식
query_id_formats 태그 내에서 지정할 수 있습니다. 포맷 문자열의 {query_id} 자리 표시자는 쿼리 ID로 대체됩니다. 태그 안에는 여러 개의 포맷 문자열을 지정할 수 있습니다.
이 기능은 쿼리 프로파일링을 쉽게 할 수 있도록 URL을 생성하는 데 사용할 수 있습니다.
예시
설정 파일
-c [ -C, --config, --config-file ]매개변수로 지정한 파일./clickhouse-client.[xml|yaml|yml]$XDG_CONFIG_HOME/clickhouse/config.[xml|yaml|yml](XDG_CONFIG_HOME이 설정되어 있지 않으면~/.config/clickhouse/config.[xml|yaml|yml])~/.clickhouse-client/config.[xml|yaml|yml]/etc/clickhouse-client/config.[xml|yaml|yml]
clickhouse-client.xml
- XML
- YAML
환경 변수 옵션
CLICKHOUSE_USER, CLICKHOUSE_PASSWORD, CLICKHOUSE_HOST로 설정할 수 있습니다.
명령줄 인수 --user, --password, --host 또는 연결 문자열이 지정된 경우, 환경 변수보다 우선합니다.
명령줄 옵션
일반 옵션
| 옵션 | 설명 | 기본값 |
|---|---|---|
-c [ -C, --config, --config-file ] <path-to-file> | 클라이언트 설정 파일이 기본 위치 중 하나에 없을 경우, 해당 설정 파일의 위치를 지정합니다. 설정 파일을 참조하십시오. | - |
--help | 사용 요약을 출력한 후 종료합니다. --verbose와 함께 사용하면 쿼리 설정을 포함한 모든 옵션을 표시합니다. | - |
--history_file <path-to-file> | 명령 이력이 저장된 파일의 경로입니다. | - |
--history_max_entries | 이력 파일에 저장할 수 있는 최대 항목 수입니다. | 1000000 (100만) |
--prompt <prompt> | 사용자 지정 프롬프트를 설정합니다. | 서버의 display_name |
--verbose | 출력 상세 수준을 높입니다. | - |
-V [ --version ] | 버전을 출력한 후 종료합니다. | - |
연결 옵션
| Option | Description | Default |
|---|---|---|
--connection <name> | 설정 파일에 있는 미리 구성된 연결 정보의 이름입니다. 연결 자격 증명을 참조하세요. | - |
-d [ --database ] <database> | 이 연결의 기본 데이터베이스로 사용할 데이터베이스를 선택합니다. | 서버 설정의 현재 데이터베이스(기본값은 default) |
-h [ --host ] <host> | 연결할 ClickHouse 서버의 호스트명입니다. 호스트명 또는 IPv4/IPv6 주소를 사용할 수 있습니다. 여러 인수로 여러 호스트를 전달할 수도 있습니다. | localhost |
--jwt <value> | 인증에 JSON Web Token (JWT)을 사용합니다. 서버 JWT 인증은 ClickHouse Cloud에서만 사용할 수 있습니다. | - |
login | IdP를 통해 인증하기 위해 device grant OAuth 흐름을 호출합니다. ClickHouse Cloud 호스트의 경우 OAuth 변수는 자동으로 추론되며, 그 외의 경우에는 --oauth-url, --oauth-client-id, --oauth-audience로 제공해야 합니다. | - |
--no-warnings | 클라이언트가 서버에 연결할 때 system.warnings의 경고를 표시하지 않습니다. | - |
--no-server-client-version-message | 클라이언트가 서버에 연결할 때 서버-클라이언트 버전 불일치 메시지를 표시하지 않습니다. | - |
--password <password> | 데이터베이스 사용자의 비밀번호입니다. 설정 파일에서 연결의 비밀번호를 지정할 수도 있습니다. 비밀번호를 지정하지 않으면 클라이언트가 비밀번호 입력을 요청합니다. | - |
--port <port> | 서버가 연결을 수락하는 포트입니다. 기본 포트는 9440(TLS) 및 9000(TLS 미사용)입니다. 참고: 클라이언트는 HTTP(S)가 아니라 네이티브 프로토콜을 사용합니다. | --secure가 지정되면 9440, 그렇지 않으면 9000입니다. 호스트명이 .clickhouse.cloud로 끝나면 항상 기본값은 9440입니다. |
-s [ --secure ] | TLS 사용 여부입니다. 포트 9440(기본 보안 포트) 또는 ClickHouse Cloud에 연결할 때 자동으로 활성화됩니다. 설정 파일에서 CA 인증서를 구성해야 할 수 있습니다. 사용 가능한 구성 설정은 서버 측 TLS 구성과 동일합니다. | 포트 9440 또는 ClickHouse Cloud에 연결할 때 자동으로 활성화됨 |
--ssh-key-file <path-to-file> | 서버 인증에 사용할 SSH 개인 키가 들어 있는 파일입니다. | - |
--ssh-key-passphrase <value> | --ssh-key-file에 지정한 SSH 개인 키의 패스프레이스입니다. | - |
--tls-sni-override <server name> | TLS를 사용하는 경우 핸드셰이크에 전달할 서버 이름(SNI)입니다. | -h 또는 --host로 지정한 호스트입니다. |
-u [ --user ] <username> | 연결에 사용할 데이터베이스 사용자입니다. | default |
--host, --port, --user, --password 옵션 대신 연결 문자열도 사용할 수 있습니다.쿼리 옵션
| Option | Description |
|---|---|
--param_<name>=<value> | 매개변수가 있는 쿼리의 매개변수에 대한 치환 값입니다. |
-q [ --query ] <query> | batch mode에서 실행할 쿼리입니다. 여러 번 지정할 수 있으며(--query "SELECT 1" --query "SELECT 2"), 세미콜론으로 구분된 여러 쿼리를 한 번에 지정할 수도 있습니다(--query "SELECT 1; SELECT 2;"). 후자의 경우 VALUES 이외의 포맷을 사용하는 INSERT 쿼리는 빈 줄로 구분해야 합니다. 매개변수 없이 단일 쿼리를 지정할 수도 있습니다: clickhouse-client "SELECT 1" --queries-file과 함께 사용할 수 없습니다. |
--queries-file <path-to-file> | 쿼리가 들어 있는 파일의 경로입니다. --queries-file은 여러 번 지정할 수 있습니다. 예: --queries-file queries1.sql --queries-file queries2.sql. --query와 함께 사용할 수 없습니다. |
-m [ --multiline ] | 지정하면 여러 줄 쿼리를 허용합니다(Enter를 눌러도 쿼리가 전송되지 않음). 쿼리는 세미콜론으로 끝날 때만 전송됩니다. |
--inline-insert-data | 데이터를 Native 형식의 블록으로 변환하는 대신, INSERT ... VALUES(및 기타 인라인 포맷)를 쿼리 텍스트에 있는 그대로 전송합니다. 서버가 인라인 데이터를 직접 구문 분석하므로 테이블(table) 구조와 컬럼(column) 기본값을 클라이언트로 다시 보내는 왕복 과정을 피할 수 있습니다. 따라서 네이티브 프로토콜을 통해 많은 소규모 삽입을 수행할 때 성능이 향상될 수 있습니다. send_table_structure_on_insert_with_inline_data를 자동으로 0으로 설정합니다. 인라인 데이터와 외부 데이터(stdin 또는 INFILE의 데이터)는 함께 사용할 수 없습니다. |
쿼리 설정
포맷 옵션
| 옵션 | 설명 | 기본값 |
|---|---|---|
-f [ --format ] <format> | 지정한 포맷으로 결과를 출력합니다. 지원되는 포맷 목록은 입력 및 출력 데이터 포맷을 참조하십시오. | TabSeparated |
--pager <command> | 모든 출력을 이 명령으로 전달합니다. 일반적으로 less(예: 가로로 긴 결과 집합을 표시하려면 less -S) 또는 이와 비슷한 명령을 사용합니다. | - |
-E [ --vertical ] | 결과를 출력할 때 Vertical 형식을 사용합니다. 이는 --format Vertical과 같습니다. 이 형식에서는 각 값이 별도의 줄에 출력되므로 열이 많은 테이블을 표시할 때 유용합니다. | - |
실행 세부 정보
| 옵션 | 설명 | 기본값 |
|---|---|---|
--enable-progress-table-toggle | 제어 키(Space)를 눌러 진행률 테이블 표시를 전환할 수 있도록 합니다. 진행률 테이블 출력이 활성화된 대화형 모드에서만 적용됩니다. | enabled |
--hardware-utilization | 진행률 표시줄에 하드웨어 사용률 정보를 출력합니다. | - |
--memory-usage | 지정하면 비대화형 모드에서 메모리 사용량을 stderr에 출력합니다. 가능한 값: • none - 메모리 사용량을 출력하지 않음 • default - 바이트 수를 출력 • readable - 사람이 읽기 쉬운 포맷으로 메모리 사용량을 출력 | - |
--print-profile-events | ProfileEvents 패킷을 출력합니다. | - |
--progress | 쿼리 실행 진행 상황을 출력합니다. 가능한 값: • tty|on|1|true|yes - 대화형 모드에서 터미널로 출력합니다 • err - 비대화형 모드에서 stderr로 출력합니다 • off|0|false|no - 진행 상황 출력을 비활성화합니다 | 대화형 모드에서는 tty, 비대화형(배치) 모드에서는 off |
--progress-table | 쿼리 실행 중 변경되는 메트릭을 표시하는 진행률 테이블을 출력합니다. 가능한 값: • tty|on|1|true|yes - 대화형 모드에서 터미널로 출력합니다 • err - 비대화형 모드에서 stderr로 출력합니다 • off|0|false|no - 진행률 테이블 출력을 비활성화합니다 | 대화형 모드에서는 tty, 비대화형(배치) 모드에서는 off |
--stacktrace | 예외의 스택 트레이스를 출력합니다. | - |
-t [ --time ] | 비대화형 모드에서 쿼리 실행 시간을 stderr에 출력합니다(벤치마크용). | - |