LIMIT n BY expressions 句を含むクエリは、expressions の値の各一意な組み合わせごとに、先頭の n 行を選択します。LIMIT BY のキーには、任意の数の expressions を含めることができます。
ClickHouse は、次の構文バリエーションをサポートしています。
LIMIT [offset_value, ]n BY expressionsLIMIT n OFFSET offset_value BY expressions
LIMIT n BY expressions を適用し、expressions の各一意な組み合わせごとに先頭の n 行を返します。OFFSET が指定されている場合、ClickHouse は expressions の一意な組み合わせに属する各 data block について、ブロックの先頭から offset_value 行をスキップし、結果として最大 n 行を返します。offset_value が data block の行数を上回る場合、ClickHouse はそのブロックからは 0 行を返します。
LIMIT BY は LIMIT とは無関係です。両方を同じクエリで使用できます。LIMIT BY 句でカラム名の代わりにカラム番号を使う場合は、設定 enable_positional_arguments を有効にしてください。
例
SELECT * FROM limit_by ORDER BY id, val LIMIT 2 OFFSET 1 BY id クエリでも同じ結果が返されます。
次のクエリは、各 domain, device_type の組み合わせごとに上位 5 件のリファラーを返し、全体の行数は最大 100 行です (LIMIT n BY + LIMIT) 。
LIMIT BY は、負の制限値やオフセットでも使用できます。negative LIMIT clause と同様に、LIMIT BY でも負の値を使って、各グループの末尾から行を選択できます。
id について最後の 2 行を返します。id = 1 では行 11 と 12 が返されます。id = 2 では、グループ内の行が 2 行しかないため、両方の行が返されます。
id について、最後から 2 番目の行を返します。末尾の OFFSET -1 で各グループの最後の行を除外し、先頭の -1 で残った行のうち最後の行を取得します。
符号の異なる LIMIT と OFFSET を組み合わせることもできます。たとえば、各グループの先頭の行を除外してから、残った行のうち末尾の 2 行を取得するには、次のようにします。
id = 1 の場合、最初の行 (10) はスキップされ、11, 12 の最後の 2 つはどちらも返されます。id = 2 の場合、最初の行 (20) はスキップされるため、21 だけが残ります。
LIMIT BY ALL
LIMIT BY ALL は、集約関数ではない SELECT 対象のすべての式を列挙するのと同等です。
たとえば:
LIMIT BY のキーには、そこから抽出できる限り多くの非集約フィールドが含まれます。
例えば:
例
SELECT * FROM limit_by ORDER BY id, val LIMIT 2 OFFSET 1 BY id クエリでも同じ結果が返されます。
LIMIT BY ALL を使用する場合: