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
相关推荐
一路往蓝-Anbo2 小时前
第 1 篇:对象池模式 (Object Pool) —— 裸机下的动态内存革命
jvm·数据库·stm32·单片机·嵌入式硬件·网络协议·tcp/ip
力学与人工智能2 小时前
“高雷诺数湍流数据库的构建及湍流机器学习集成研究”湍流重大研究计划集成项目顺利结题
数据库·人工智能·机器学习·高雷诺数·湍流·重大研究计划·项目结题
TDengine (老段)2 小时前
TDengine 脱敏函数用户手册
大数据·服务器·数据库·物联网·时序数据库·iot·tdengine
weixin_446260852 小时前
[特殊字符] 使用 PageIndex 提升文档检索效率,告别向量数据库的局限!
数据库
TsengOnce2 小时前
Docker 安装达梦8数据库-5步成功
java·数据库
存在的五月雨3 小时前
Mysql 函数
数据库·mysql
m0_561359673 小时前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python
前方一片光明3 小时前
SQL SERVER—将所有表的cjsj字段改为datetime2(0),去掉毫秒
数据库
老邓计算机毕设3 小时前
SSM医院疫情管理系统e3oxi(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·医疗信息化·ssm 框架·医院疫情管理系统