インストール
実行
ClickHouse をダウンロードしただけでインストールしていない場合は、
clickhouse-client ではなく ./clickhouse client を使用してください。| Option | Description |
|---|---|
--port <port> | ClickHouse server が接続を受け付けるポートです。デフォルトのポートは 9440 (TLS) と 9000 (TLS なし) です。ClickHouse Client は HTTP(S) ではなくネイティブプロトコルを使用する点に注意してください。 |
-s [ --secure ] | TLS を使用するかどうかを指定します (通常は自動検出されます) 。 |
-u [ --user ] <username> | 接続に使用するデータベースユーザーです。デフォルトでは default ユーザーとして接続します。 |
--password <password> | データベースユーザーのパスワードです。設定ファイルで接続用のパスワードを指定することもできます。パスワードを指定しない場合、クライアントが入力を求めます。 |
-c [ --config ] <path-to-file> | ClickHouse Client の設定ファイルの場所です (デフォルトの場所のいずれにもない場合) 。Configuration Files を参照してください。 |
--connection <name> | configuration file で事前設定された接続情報の名前です。 |
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;
クエリ処理情報
- Progress。デフォルトでは、1 秒あたり最大 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 でヒアドキュメントが開始され、再度 _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 キー。環境変数で設定している場合は省略できます。- OpenAI:
OPENAI_API_KEY - Anthropic:
ANTHROPIC_API_KEY - 注: 設定ファイル内の API キーは環境変数より優先されます
- 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 = 決定論的、1.0 = 創造的 (デフォルト:0.0)max_tokens- 応答の最大長 (トークン数) (デフォルト:1000)system_prompt- AI へのカスタム指示 (任意)
仕組み
- スキーマの検出
- 利用可能なデータベースを一覧表示します
- 関連するデータベース内のテーブルを検出します
CREATE TABLEステートメントを通じてテーブル構造を調べます
- クエリ生成
- 自然言語で表した意図に合致する
- 正しいテーブル名とカラム名を使用する
- 適切な JOIN と集計を適用する
- 実行
制限事項
- 有効なインターネット接続が必要です
- API の利用には、AIプロバイダーによるレート制限やコストが伴います
- 複雑なクエリでは、複数回の調整が必要になる場合があります
- AI が読み取り専用でアクセスできるのはスキーマ情報のみで、実際のデータにはアクセスできません
セキュリティ
- API キーが ClickHouse サーバーに送信されることはありません
- AI が参照するのはスキーマ情報 (テーブル名 / カラム名 / 型) のみで、実際のデータは参照しません
- 生成されるすべてのクエリは、既存のデータベース権限に従います
接続文字列
使用方法
| 構成要素 (すべて省略可能) | 説明 | デフォルト |
|---|---|---|
user | データベースのユーザー名。 | default |
password | データベースユーザーのパスワード。: が指定され、かつパスワードが空の場合、クライアントはユーザーのパスワードの入力を求めます。 | - |
hosts_and_ports | ホストと省略可能なポートのリスト host[:port] [, host:[port]], ...。 | localhost:9000 |
database | データベース名。 | default |
query_parameters | キー・バリューのペアのリスト param1=value1[,¶m2=value2], ...。一部のパラメーターでは値は不要です。パラメーター名と値では大文字と小文字が区別されます。 | - |
注記
--user、--password、--database では指定できません (逆も同様です) 。
ホスト部分には、ホスト名または IPv4 / IPv6 アドレスを指定できます。
IPv6 アドレスは [] で囲む必要があります。
clickHouse-client の最初の引数として指定する必要があります。
接続文字列は、--host と --port を除き、任意個のほかのコマンドラインオプションと組み合わせて使用できます。
query_parameters では、次のキーを使用できます。
| Key | Description |
|---|---|
secure (or s) | 指定すると、クライアントは安全な接続 (TLS) でサーバーに接続します。コマンドラインオプションの --secure を参照してください。 |
userpasswordhostsdatabasequery parameters
例
localhost のポート9000に接続し、クエリ SELECT 1 を実行します。
john として、パスワード secret、ホスト 127.0.0.1、ポート 9000 を指定して localhost に接続します
localhost (IPV6 アドレス [::1]、ポート 9000) に default ユーザーとして接続します。
localhost のポート 9000 に接続します。
default として、ポート9000で localhost に接続します。
localhost のポート9000に接続し、デフォルトのデータベースとして my_database を使用します。
localhost に接続し、接続文字列で指定した 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、または接続文字列 (指定した場合) は、環境変数よりも優先されます。
コマンドラインオプション
一般オプション
| Option | Description | Default |
|---|---|---|
-c [ -C, --config, --config-file ] <path-to-file> | クライアントの設定ファイルが既定の場所にない場合は、そのファイルの場所を指定します。Configuration Files を参照してください。 | - |
--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 server のホスト名です。ホスト名、IPv4 アドレス、IPv6 アドレスのいずれかを指定できます。複数の引数を指定して複数のホストを渡すこともできます。 | localhost |
--jwt <value> | 認証に JSON Web Token (JWT) を使用します。 サーバー側の JWT 認可は ClickHouse Cloud でのみ利用できます。 | - |
login | IdP 経由で認証するために、デバイス 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 オプションの代わりに、クライアントは接続文字列もサポートしています。クエリオプション
| オプション | 説明 |
|---|---|
--param_<name>=<value> | パラメータ付きクエリ のパラメータに使用する置換値です。 |
-q [ --query ] <query> | バッチモードで実行するクエリです。複数回指定することも (--query "SELECT 1" --query "SELECT 2")、セミコロンで区切った複数のクエリを 1 回で指定することもできます (--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 | INSERT ... VALUES (およびその他のインラインフォーマット) を、データをネイティブフォーマットのブロックに変換せず、クエリテキスト内にそのまま含めて送信します。サーバー側でインラインデータを直接解析するため、テーブル構造やカラムのデフォルト値をクライアントに返すための往復を省けます。これにより、ネイティブプロトコル経由で多数の小さな insert を行う場合のパフォーマンスが向上することがあります。send_table_structure_on_insert_with_inline_data は自動的に 0 に設定されます。インラインデータと外部データ (stdin または INFILE からのデータ) は併用できません。 |
クエリ設定
フォーマットオプション
| Option | Description | Default |
|---|---|---|
-f [ --format ] <format> | 指定したフォーマットで結果を出力します。 対応フォーマットの一覧については、入出力データのフォーマットを参照してください。 | TabSeparated |
--pager <command> | すべての出力をこのコマンドにパイプして渡します。通常は less (例: 幅の広い結果セットを表示するための less -S) などを使用します。 | - |
-E [ --vertical ] | 結果の出力に Vertical フォーマット を使用します。これは --format Vertical と同じです。このフォーマットでは各値が別々の行に表示されるため、列数の多いテーブルを表示するときに便利です。 | - |
実行の詳細
| Option | Description | Default |
|---|---|---|
--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に表示します (ベンチマーク用) 。 | - |