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
相关推荐
许彰午1 分钟前
CacheSQL(五):桥接篇
java·数据库·缓存·系统架构
七夜zippoe7 分钟前
# DolphinDB分区策略:RANGE分区详解
数据库·策略·分区·range·dolphindb
地球资源数据云19 分钟前
中国陆地生态系统主要植物功能特征空间分布数据
大数据·数据库·人工智能·机器学习
吠品25 分钟前
高性能JS数组操作:何时选用push、unshift、splice或扩展运算符?
linux·服务器·数据库
洛水水33 分钟前
【Redis入门】一篇详解Redis五大数据结构
数据结构·数据库·redis
woodykissme38 分钟前
日产汽车花键测绘,为什么总踩坑?
数据库·汽车·齿轮·渐开线花键
雨辰AI1 小时前
从 MySQL 迁移至人大金仓 V9 完整改造指南|分页 / 函数 / 语法兼容全部解决
java·开发语言·数据库·后端·mysql·政务
狼与自由1 小时前
clickhouse 查询
clickhouse
Chengbei111 小时前
AI大模型网关存在SQL注入、影响版本LiteLLM 1.81.16~1.83.7(CVE-2026-42208)
数据库·人工智能·sql·安全·web安全·网络安全·系统安全
zx2859634001 小时前
Laravel 9.x:全面升级与核心特性
数据库