clickhouse 实现mysql GROUP_CONCAT() 函数

mysql GROUP_CONCAT() 函数

这是 MySQL 中用于分组字符串拼接的唯一标准聚合函数

创建示例数据表

sql 复制代码
-- 创建水果信息表
CREATE TABLE fruits (
    id INT PRIMARY KEY AUTO_INCREMENT,
    fruit_name VARCHAR(50) NOT NULL COMMENT '水果名称',
    origin VARCHAR(100) NOT NULL COMMENT '来源地/产地',
    variety VARCHAR(50) COMMENT '品种',
    harvest_month VARCHAR(20) COMMENT '收获月份',
    price DECIMAL(8,2) COMMENT '价格(元/公斤)',
    quantity INT DEFAULT 0 COMMENT '库存数量',
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '记录创建时间'
) COMMENT='水果信息表';

-- 插入示例数据
INSERT INTO fruits (fruit_name, origin, variety, harvest_month, price, quantity) VALUES
('苹果', '山东烟台', '红富士', '9-11月', 12.50, 150),
('苹果', '陕西延安', '嘎啦', '7-9月', 9.80, 200),
('苹果', '新疆阿克苏', '冰糖心', '10-12月', 15.80, 80),
('苹果', '山东烟台', '国光', '10-11月', 8.50, 100),
('香蕉', '海南三亚', '巴西蕉', '全年', 6.50, 300),
('香蕉', '广西南宁', '小米蕉', '全年', 7.20, 180),
('香蕉', '广东湛江', '威廉斯', '全年', 5.90, 250),
('橙子', '江西赣南', '脐橙', '11-1月', 10.80, 120),
('橙子', '湖北秭归', '血橙', '12-2月', 13.50, 90),
('橙子', '重庆奉节', '脐橙', '11-1月', 11.20, 110),
('葡萄', '新疆吐鲁番', '无核白', '7-9月', 18.00, 60),
('葡萄', '河北张家口', '巨峰', '8-10月', 12.50, 140),
('葡萄', '山东烟台', '玫瑰香', '8-10月', 15.00, 75),
('荔枝', '广东茂名', '妃子笑', '5-7月', 25.00, 50),
('荔枝', '广西钦州', '桂味', '6-7月', 28.00, 40),
('芒果', '海南三亚', '贵妃芒', '3-6月', 16.50, 95),
('芒果', '广西百色', '台农芒', '6-8月', 12.80, 110),
('芒果', '四川攀枝花', '凯特芒', '8-11月', 14.20, 85);

按来源地分组显示水果

sql 复制代码
SELECT 
    origin AS '来源地',
    GROUP_CONCAT(fruit_name) AS '水果列表'
FROM fruits
GROUP BY origin

clickhouse 实现 GROUP_CONCAT() 功能

  1. groupArray:将分组内的值组成一个数组。

  2. replaceRegexpAll 去掉 '[]'

创建示例数据

sql 复制代码
CREATE TABLE fruits (
    id UInt64,
    fruit_name String,
    origin String,
    variety Nullable(String),
    harvest_month Nullable(String),
    price Nullable(Float64),
    quantity Int32 DEFAULT 0,
    created_at DateTime DEFAULT now()
) ENGINE = MergeTree()
ORDER BY (id, fruit_name)
SETTINGS index_granularity = 8192;

INSERT INTO fruits (id, fruit_name, origin, variety, harvest_month, price, quantity) VALUES
(1, '苹果', '山东烟台', '红富士', '9-11月', 12.50, 150),
(2, '苹果', '陕西延安', '嘎啦', '7-9月', 9.80, 200),
(3, '苹果', '新疆阿克苏', '冰糖心', '10-12月', 15.80, 80),
(4, '苹果', '山东烟台', '国光', '10-11月', 8.50, 100),
(5, '香蕉', '海南三亚', '巴西蕉', '全年', 6.50, 300),
(6, '香蕉', '广西南宁', '小米蕉', '全年', 7.20, 180),
(7, '香蕉', '广东湛江', '威廉斯', '全年', 5.90, 250),
(8, '橙子', '江西赣南', '脐橙', '11-1月', 10.80, 120),
(9, '橙子', '湖北秭归', '血橙', '12-2月', 13.50, 90),
(10, '橙子', '重庆奉节', '脐橙', '11-1月', 11.20, 110),
(11, '葡萄', '新疆吐鲁番', '无核白', '7-9月', 18.00, 60),
(12, '葡萄', '河北张家口', '巨峰', '8-10月', 12.50, 140),
(13, '葡萄', '山东烟台', '玫瑰香', '8-10月', 15.00, 75),
(14, '荔枝', '广东茂名', '妃子笑', '5-7月', 25.00, 50),
(15, '荔枝', '广西钦州', '桂味', '6-7月', 28.00, 40),
(16, '芒果', '海南三亚', '贵妃芒', '3-6月', 16.50, 95),
(17, '芒果', '广西百色', '台农芒', '6-8月', 12.80, 110),
(18, '芒果', '四川攀枝花', '凯特芒', '8-11月', 14.20, 85);

按来源地分组显示水果

sql 复制代码
 select  
       origin,
       replaceRegexpAll(toString(groupArray(fruit_name)), '[\[\]\']', '') fruit_name
  from fruits
 group by origin
相关推荐
·云扬·7 分钟前
MySQL Redo Log落盘机制深度解析
数据库·mysql
用户9828630256820 分钟前
pg内核实现细节
数据库
码界筑梦坊23 分钟前
330-基于Python的社交媒体舆情监控系统
python·mysql·信息可视化·数据分析·django·毕业设计·echarts
飞升不如收破烂~27 分钟前
Redis 分布式锁+接口幂等性使用+当下流行的限流方案「落地实操」+用户连续点击两下按钮的解决方案自用总结
数据库·redis·分布式
workflower29 分钟前
业务需求-假设场景
java·数据库·测试用例·集成测试·需求分析·模块测试·软件需求
亓才孓43 分钟前
[JDBC]基于三层架构和MVC架构的JDBCTools
数据库
IT邦德1 小时前
RPM包快速安装Oracle26ai
数据库·oracle
Dovis(誓平步青云)1 小时前
《滑动窗口算法:从 “暴力遍历” 到 “线性高效” 的思维跃迁》
运维·服务器·数据库·算法
mr_LuoWei20091 小时前
python工具:python代码知识库笔记
数据库·python
这周也會开心1 小时前
Redis数据类型的底层实现和数据持久化
数据库·redis·缓存