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

groupArrayArray

複数の配列を集約し、それらを要素とするより大きな配列を生成します。 groupArray 関数と Array コンビネータを組み合わせたものです。

別名: array_concat_agg

ユーザーの閲覧セッションを記録したデータがあるとします。各セッションには、特定のユーザーが閲覧したページの順序が記録されています。 groupArrayArray 関数を使用することで、各ユーザーのページ閲覧パターンを分析できます。

CREATE TABLE website_visits (
    user_id UInt32,
    session_id UInt32,
    page_visits Array(String)
) ENGINE = Memory;

INSERT INTO website_visits VALUES
(101, 1, ['homepage', 'products', 'checkout']),
(101, 2, ['search', 'product_details', 'contact']),
(102, 1, ['homepage', 'about_us']),
(101, 3, ['blog', 'homepage']),
(102, 2, ['products', 'product_details', 'add_to_cart', 'checkout']);
SELECT
    user_id,
    groupArrayArray(page_visits) AS user_session_page_sequences
FROM website_visits
GROUP BY user_id;
   ┌─user_id─┬─user_session_page_sequences───────────────────────────────────────────────────────────────┐
1. │     101 │ ['homepage','products','checkout','search','product_details','contact','blog','homepage'] │
2. │     102 │ ['homepage','about_us','products','product_details','add_to_cart','checkout']             │
   └─────────┴───────────────────────────────────────────────────────────────────────────────────────────┘