listagg、xmlagg、group_concat()函数用法

2024-02-02 10:36

本文主要是介绍listagg、xmlagg、group_concat()函数用法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

三种聚合函数

  • listagg函数
  • XMLAGG函数
  • GROUP_CONCAT()函数

listagg函数

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

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

将符合某条件的全部数据中的地区名称罗列出来,并以“|”分隔开
数据库语句为

SELECT LISTAGG(AREA_NAME, '|') WITHIN GROUP (ORDER BY AREA_CODE) AS NAME_LIST FROM AREAS;

返回结果:

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

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

XMLAGG函数

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

SELECT TRIM(BOTHFROMXMLAGG(XMLELEMENT(E,AREA_NAME || ',') ORDER BY AREA_CODE).EXTRACT('//text()')AS NAME_LISTFROM AREAS;

或者换一种写法:

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()函数:

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

也可以通过命令设置

SET GLOBAL group_concat_max_len = 102400;
SET SESSION group_concat_max_len = 102400;

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

这篇关于listagg、xmlagg、group_concat()函数用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/670435

相关文章

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

MyBatis-Flex BaseMapper的接口基本用法小结

《MyBatis-FlexBaseMapper的接口基本用法小结》本文主要介绍了MyBatis-FlexBaseMapper的接口基本用法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具... 目录MyBATis-Flex简单介绍特性基础方法INSERT① insert② insertSelec

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

MySQL报错sql_mode=only_full_group_by的问题解决

《MySQL报错sql_mode=only_full_group_by的问题解决》本文主要介绍了MySQL报错sql_mode=only_full_group_by的问题解决,文中通过示例代码介绍的非... 目录报错信息DataGrip 报错还原Navicat 报错还原报错原因解决方案查看当前 sql mo

深入解析Spring TransactionTemplate 高级用法(示例代码)

《深入解析SpringTransactionTemplate高级用法(示例代码)》TransactionTemplate是Spring框架中一个强大的工具,它允许开发者以编程方式控制事务,通过... 目录1. TransactionTemplate 的核心概念2. 核心接口和类3. TransactionT

数据库使用之union、union all、各种join的用法区别解析

《数据库使用之union、unionall、各种join的用法区别解析》:本文主要介绍SQL中的Union和UnionAll的区别,包括去重与否以及使用时的注意事项,还详细解释了Join关键字,... 目录一、Union 和Union All1、区别:2、注意点:3、具体举例二、Join关键字的区别&php

Java function函数式接口的使用方法与实例

《Javafunction函数式接口的使用方法与实例》:本文主要介绍Javafunction函数式接口的使用方法与实例,函数式接口如一支未完成的诗篇,用Lambda表达式作韵脚,将代码的机械美感... 目录引言-当代码遇见诗性一、函数式接口的生物学解构1.1 函数式接口的基因密码1.2 六大核心接口的形态学

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,