首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在clickhouse中聚合时如何计数元素?

在clickhouse中聚合时如何计数元素?
EN

Stack Overflow用户
提问于 2022-05-26 09:32:36
回答 2查看 240关注 0票数 0

我有这样的数据

customer_id - product_id

1- 10

1-11

1- 12

1-11

2- 15

2- 20

在聚合之后,我想得到:

customer_id - product_id

{10:1,11:2,12:1}

2- {15:1,20:1}

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2022-05-26 17:02:17

请尝试以下查询:

代码语言:javascript
复制
SELECT
    customer_id,
    arrayMap((product_id, count) -> (product_id, count),
        untuple(sumMap([product_id], [1]))) AS result
FROM 
(
    /* Emulate the test dataset. */
    SELECT
        data.1 AS customer_id,
        data.2 AS product_id
    FROM 
    (
        SELECT arrayJoin([(1, 10), (1, 11), (1, 12), (1, 11), 
                          (2, 15), (2, 20)]) AS data
    )
)
GROUP BY customer_id

/*
┌─customer_id─┬─result─────────────────┐
│           1 │ [(10,1),(11,2),(12,1)] │
│           2 │ [(15,1),(20,1)]        │
└─────────────┴────────────────────────┘
*/
票数 0
EN

Stack Overflow用户

发布于 2022-05-26 19:10:49

代码语言:javascript
复制
WITH dataset AS
    (
        SELECT
            data.1 AS customer_id,
            data.2 AS product_id
        FROM
        (
            SELECT arrayJoin([
              (1, 10), (1, 11), (1, 12), (1, 11), (2, 15), (2, 20)
            ]) AS data
        )
    )



SELECT
    customer_id,
    arrayMap(
      x -> (x, arrayCount(y -> (y = x), groupArray(product_id) AS product_ids)),
      arrayDistinct(product_ids)
    ) AS result
FROM dataset
GROUP BY customer_id

┌─customer_id─┬─result─────────────────┐
│           1 │ [(10,1),(11,2),(12,1)] │
│           2 │ [(15,1),(20,1)]        │
└─────────────┴────────────────────────┘
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72389687

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档