メインコンテンツへスキップ

ClickStack と Elastic での検索

ClickHouse は SQL ネイティブの engine であり、高性能な分析ワークロード向けにゼロから設計されています。一方、Elasticsearch は SQL ライクなインターフェイスを提供し、SQL を基盤となる Elasticsearch の query DSL に変換します。つまり、SQL は第一級の機能ではなく、機能面での互換性 も限定的です。 ClickHouse は完全な SQL をサポートするだけでなく、argMaxhistogramquantileTiming のようなオブザーバビリティ向けのさまざまな関数も備えており、構造化されたログ、メトリクス、トレースに対するクエリを簡潔に記述できます。 シンプルなログやトレースの調査には、ClickStack UI (HyperDX) が、フィールドと値によるクエリ、範囲指定、ワイルドカードなどに対応した、直感的なテキストベースの絞り込みを行える Lucene スタイルの構文 を提供します。これは、Elasticsearch の Lucene 構文 や、Kibana Query Language の一部に相当します。 この検索インターフェイスは、こうした馴染みのある構文をサポートしつつ、内部ではそれを効率的な SQL の WHERE 句に変換します。そのため、Kibana ユーザーにも親しみやすく、必要に応じて SQL の強力な機能も活用できます。これにより、ClickHouse の 文字列検索関数類似度関数日時関数 を幅広く活用できます。 以下では、ClickStack と Elasticsearch の Lucene クエリ言語を比較します。

ClickStack 検索構文と Elasticsearch query string の比較

ClickStack と Elasticsearch はどちらも、ログや トレース を直感的にフィルタリングできる柔軟なクエリ言語を提供しています。Elasticsearch の query string は DSL と索引エンジンに密接に統合されている一方、ClickStack は内部的に ClickHouse SQL に変換される、Lucene に着想を得た構文をサポートしています。以下の表では、一般的な検索パターンが両システムでどのように動作するかを示し、構文上の共通点とバックエンドでの実行方法の違いをまとめています。
機能ClickStack 構文Elasticsearch 構文コメント
自由テキスト検索errorerrorすべての索引済みフィールドを対象に一致します。ClickStack では、複数フィールドに対する SQL ILIKE に書き換えられます。
フィールド一致level:errorlevel:error構文は同一です。ClickStack では ClickHouse 内のフィールド値に完全一致します。
フレーズ検索"disk full""disk full"引用符で囲んだテキストは、完全に同じ語順の並びに一致します。ClickHouse では文字列の等価比較または ILIKE を使用します。
フィールドのフレーズ一致message:"disk full"message:"disk full"SQL ILIKE または完全一致に変換されます。
OR 条件error OR warningerror OR warning用語の論理 OR です。どちらのシステムでもネイティブにサポートされます。
AND 条件error AND dberror AND dbどちらも積集合として扱われ、ユーザー向けの構文に違いはありません。
否定NOT error or -errorNOT error or -errorどちらも同様にサポートされます。ClickStack では SQL NOT ILIKE に変換されます。
グループ化(error OR fail) AND db(error OR fail) AND dbどちらでも標準的なブール条件のグループ化です。
ワイルドカードerror* or *fail*error*, *fail*ClickStack は先頭および末尾のワイルドカードをサポートします。ES はパフォーマンス上の理由から、デフォルトで先頭ワイルドカードを無効にしています。用語の途中にワイルドカードを入れることはできません。たとえば f*ail. はサポートされません。ワイルドカードはフィールド一致と組み合わせて使用する必要があります。
範囲 (数値/日付)duration:[100 TO 200]duration:[100 TO 200]ClickStack は SQL BETWEEN を使用します。Elasticsearch は range クエリに展開します。範囲内での無制限 * はサポートされません。たとえば duration:[100 TO *] は使用できません。必要な場合は、以下の Unbounded ranges を使用してください。
非有界範囲 (数値/日付)duration:>10 or duration:>=10duration:>10 or duration:>=10ClickStack は標準の SQL 演算子を使用します
包含/排他duration:{100 TO 200} (exclusive)Same{} は排他的な境界を表します。範囲内の * はサポートされません。たとえば duration:[100 TO *] は使用できません
存在チェックN/A_exists_:user or field:*_exists_ はサポートされていません。LogAttributes などの Map カラムには LogAttributes.log.file.path: * を使用してください。ルートカラムは常に存在する必要があり、イベントに含まれていない場合はデフォルト値が入ります。デフォルト値または欠落カラムを検索する場合は、Elasticsearch と同じ構文 ServiceName:* または ServiceName != '' を使用します。
正規表現match functionname:/joh?n(ath[oa]n)/現時点では Lucene 構文ではサポートされていません。SQL と match function、またはその他の string search functions を使用できます。
あいまい一致editDistance('quikc', field) = 1quikc~現時点では Lucene 構文ではサポートされていません。Distance functions は SQL で使用できます。たとえば editDistance('rror', SeverityText) = 1other similarity functions を利用できます。
近接検索サポートされていません"fox quick"~5現時点では Lucene 構文ではサポートされていません。
ブーストquick^2 foxquick^2 fox現時点で ClickStack ではサポートされていません。
フィールドワイルドカードservice.*:errorservice.*:error現時点で ClickStack ではサポートされていません。
特殊文字のエスケープ予約文字は \ でエスケープしますSame予約記号はエスケープが必要です。

Exists/missing の違い

イベント内でフィールド自体を完全に省略でき、その結果として本当に「存在しない」状態になり得る Elasticsearch とは異なり、ClickHouse ではテーブルのスキーマに定義されたすべてのカラムが必ず存在します。insert イベントでフィールドが指定されていない場合は、次のようになります。
  • Nullable フィールドでは、NULL が設定されます。
  • 非 Nullable フィールド (デフォルト) では、デフォルト値 (多くの場合は空文字列、0、またはそれに相当する値) が設定されます。
ClickStack では、Nullable推奨されていないため、後者を使用します。 この挙動により、Elasticsearch の意味でフィールドが「存在する」かどうかを確認することは、直接的にはサポートされていません。 代わりに、空でない値があるかどうかは、field:* または field != '' を使って確認できます。そのため、実際に欠落しているフィールドと、明示的に空のフィールドを区別することはできません。 実運用では、この違いがオブザーバビリティのユースケースで問題になることはほとんどありませんが、システム間でクエリを移行する際には、この点を意識しておくことが重要です。
最終更新日 2026年6月10日