gbase&oracle行转列函数
转:https://blog.csdn.net/manonggeerdan/article/details/126299268?share_token=27704f7a-a864-49b2-b294-4586956169bd
一、group_concat(适用于mysql、gbase)
1、功能:
将group by产生的同一个分组中的值连接起来,返回一个字符串结果。
2、语法:
group_concat( [distinct] 要连接的字段 [order by 排序字段 asc/desc ] [separator ‘分隔符’] )
说明:通过使用distinct可以排除重复值;如果希望对结果中的值进行排序,可以使用order by子句;separator是一个字符串值,缺省为一个逗号。
测试
准备数据
drop table if exists t_orders; create table t_orders ( id int primary key auto_increment, userId int, orderId varchar(20) ); insert into t_orders(userId, orderId) values(1, '100'); insert into t_orders(userId, orderId) values(1, '101'); insert into t_orders(userId, orderId) values(1, '102'); insert into t_orders(userId, orderId) values(2, '200'); insert into t_orders(userId, orderId) values(2, '201'); insert into t_orders(userId, orderId) values(3, '300');
-- (1)普通查询 select userId as 用户ID, orderId as 订单 from t_orders; -- (2)以 userId 分组,把 orderId 字段的值打印在一行,逗号分隔 select userId as 用户ID, group_concat(orderId) as 订单 from t_orders group by userId; -- (3)以 userId 分组,把 orderId 字段的值打印在一行,分号分隔 select userId as 用户ID, group_concat(orderId separator ';') as 订单 from t_orders group by userId; -- (4)以 userId 分组,把 orderId 字段的值打印在一行,降序排列 select userId as 用户ID, group_concat(orderId order by orderId desc) as 订单列表 from t_orders group by userId;
(1):
(2):
(3):
(4):
二、group_concat(适用于Oracle)
-- (3) select userId as 用户ID, LISTAGG(orderid, ',') WITHIN GROUP (ORDER BY orderid) as 订单 from t_orders group by userId; -- (4) select LISTAGG(orderid, ',') WITHIN GROUP (ORDER BY orderid) as orderid from t_orders t order by orderid desc;
« 上一篇: cron 表达式与crontab表达式详解
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?