ClickHouse是一个面向列的分布式数据库管理系统,它提供了丰富的聚合函数来对数据进行分析和处理。其中,groupUniqArray是一种聚合函数,用于在对数据进行分组时,将每个组内的唯一值组合成一个数组。
让我们通过一个示例来解释groupUniqArray的用法。假设我们有一个包含用户ID和其所喜欢的水果的数据表,我们想要按照用户ID进行分组,并将每个用户喜欢的水果收集到一个数组中。
假设我们有以下数据:
| User ID | Favorite Fruit |
|---|---|
| 1 | Apple |
| 1 | Banana |
| 2 | Apple |
| 2 | Orange |
| 2 | Banana |
| 3 | Orange |
| 3 | Banana |
| 3 | Apple |
现在,我们想要按用户ID进行分组,并将每个用户所喜欢的水果收集到一个数组中。我们可以使用groupUniqArray函数来实现这一目的。
sql
SELECT
UserID,
groupUniqArray(FavoriteFruit) AS FavoriteFruits
FROM
MyTable
GROUP BY
UserID
执行上述查询后,我们将得到以下结果:
| UserID | FavoriteFruits |
|---|---|
| 1 | ['Apple', 'Banana'] |
| 2 | ['Apple', 'Orange', 'Banana'] |
| 3 | ['Orange', 'Banana', 'Apple'] |
这样,我们就实现了按用户ID分组,并将每个用户所喜欢的水果收集到一个数组中的功能。groupUniqArray函数确保在每个数组中只包含唯一的水果值。