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
相关推荐
jiayou649 小时前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北10 小时前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤1 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12022 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区2 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1772 天前
《从零搭建NestJS项目》
数据库·typescript
加号33 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏3 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐3 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再3 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip