listagg、xmlagg、group_concat()函数用法

三种聚合函数

listagg函数

listagg 是oracle数据库中的函数,可以使用指定连接符将字符串连接。

如有表 AREAS:

sql 复制代码
CREATE TABLE AREAS
(
	AREA_CODE VARCHAR(32) NULL COMMENT '地区编码',
	AREA_NAME VARCHAR(32) NULL COMMENT '地区名称',
	AREA_PID VARCHAR(32) NULL COMMENT '父级地区编码'
);

将符合某条件的全部数据中的地区名称罗列出来,并以"|"分隔开

数据库语句为

sql 复制代码
SELECT LISTAGG(AREA_NAME, '|') WITHIN GROUP (ORDER BY AREA_CODE) AS NAME_LIST FROM AREAS;

返回结果:

北京市|长沙市|长沙县|万科城市花园|重庆市|房聚首府小区|芙蓉区|衡阳市|黄冈市|黄石市|湖北省|湖南省|荆门市|君山区|君山壹号|开福区|浏阳市|宁乡市|上海市|天津市|天心区|望城区......

这种方式的缺点是长度有限。返回值为VARCHAR2类型,最大字节长度为4000,超过这个长度会报错。

XMLAGG函数

同样的表,同样的条件,使用XMLAGG函数:

sql 复制代码
SELECT TRIM(BOTH
            FROM
            XMLAGG(
                    XMLELEMENT(
                            E,
                            AREA_NAME || ',') ORDER BY AREA_CODE).EXTRACT('//text()')
           AS NAME_LIST
            FROM AREAS;

或者换一种写法:

sql 复制代码
SELECT XMLAGG(
    XMLPARSE(
        CONTENT AREA_NAME || '|' WELLFORMED
        ) ORDER BY AREA_CODE).GETCLOBVAL()
FROM AREAS;

XMLAGG函数在长度限制方面要更宽松,返回的类型为CLOB,最大字节长度为32767。

GROUP_CONCAT()函数

上述两种均是oracle中的函数。

GROUP_CONCAT()是mysql中的函数。

同样的表和查询,在mysql数据库中,使用group_concat()函数:

sql 复制代码
SELECT GROUP_CONCAT(AREA_NAME ORDER BY AREA_CODE ASC SEPARATOR '|') AS NAME_LIST FROM AREAS;

GROUP_CONCAT()函数的长度限制为1024字节。

不过可以通过数据库配置来修改这个长度,最大可以设置为102400。

可以通过修改my.ini配置文件方式进行设置

group_concat_max_len = 102400

也可以通过命令设置

sql 复制代码
SET GLOBAL group_concat_max_len = 102400;
SET SESSION group_concat_max_len = 102400;

需要注意的是,设置后,需要重启 mysql 服务

相关推荐
搬码红绿灯几秒前
MySQL主从复制深度解析:原理、架构与实战部署指南
数据库·mysql·架构
远方160924 分钟前
16-Oracle 23 ai-JSON-Relational Duality-知识准备
数据库·oracle·json
Wooden-Flute29 分钟前
七、数据库的完整性
数据库·oracle
珹洺1 小时前
数据库系统概论(十七)超详细讲解数据库规范化与五大范式(从函数依赖到多值依赖,再到五大范式,附带例题,表格,知识图谱对比带你一步步掌握)
java·数据库·sql·安全·oracle
逝水如流年轻往返染尘2 小时前
MySQL中的内置函数
数据库·mysql
咖啡啡不加糖3 小时前
深入理解MySQL死锁:从原理、案例到解决方案
java·数据库·mysql
为中华崛起而奋斗3 小时前
Oracle 19c RAC集群ADG搭建
数据库·oracle
开挖掘机上班4 小时前
mysql已经安装,但是通过rpm -q 没有找mysql相关的已安装包
数据库·mysql
花月C4 小时前
Mysql-定时删除数据库中的验证码
数据库·后端·mysql·spring