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 服务

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/661954.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

我已经入驻多多

我已经入驻多多面包多平台 啦! 作为一位专注于帮助人们部署Python环境、探索人工智能和JavaEE技术,并创作计算机课程设计相关作品的创作者。我的作品类型涵盖了各种技术领域,旨在为学习者提供实用的资源和指导。 在CSDN拥有1100个粉丝的基础上&#x…

Spring源码研究导航

前言 这是我拜读源码的成果,大家好好珍惜,未来会有更多的更新。 目录 Spring的事件监听机制 BeanFactory创建过程(基于Servlet)

【学习心得】Django框架自带的密码加解密方法

一、前端代码 &#xff08;1&#xff09;保存原始密码&#xff08;以学生注册为例&#xff09; <form action"{% url student:register %}" method"post" id"form" >{% csrf_token %}<input type"text" name"stu_name…

arcgis javascript api4.x加载非公开或者私有的arcgis地图服务

需求&#xff1a; 加载arcgis没有公开或者私有的地图服务&#xff0c;同时还想实现加载时不弹出登录窗口 提示&#xff1a;​ 下述是针对独立的arcgis server&#xff0c;没有portal的应用场景&#xff1b; 如果有portal可以参考链接&#xff1a;https://mp.weixin.qq.com/s/W…

Spark streaming写入delta数据湖问题

问题1 一个batch运行时间过长 检查发现问题出现在merge写文件时间过长&#xff0c;一个batch本来应该是控制在1min。但项目上线到生产环境&#xff0c;检查spark streaming的job&#xff0c;发现数据在merge写入到数据湖时&#xff0c;往往超过1小时。继续排查&#xff0c;发现…

php工厂模式

在PHP中&#xff0c;工厂模式是一种创建型设计模式&#xff0c;用于将对象的创建过程封装到一个单独的类&#xff08;即工厂类&#xff09;中。通过使用工厂模式&#xff0c;客户端代码不需要知道如何实例化具体的产品类&#xff0c;而是直接与抽象接口或工厂进行交互&#xff…

MapStruct 使用

MapStruct最详细的使用教程&#xff0c;别在用BeanUtils.copyProperties () mapstruct使用和详解 项目背景 之前查看网上别人写的文章&#xff0c;很多都提到了BeanUtils(org.springframework.beans) 利用反射性能比较差。大家都推荐使用 MapStruct。因为这个组件使用 Java 原…

zookeeper 应该这样学

ZooKeeper 是一个分布式的&#xff0c;开放源码的分布式应用程序协调服务&#xff0c;是 Google 的 Chubby 一个开源的实现&#xff0c;是 Hadoop 和 Hbase 的重要组件。它是一个为分布式应用提供一致性服务的软件&#xff0c;提供的功能包括&#xff1a;配置维护、域名服务、分…

C# 使用 MailKit 接收邮件(附demo)

C# 使用 MailKit 接收邮件&#xff08;附demo&#xff09; 介绍安装包&#xff08;依赖&#xff09;案例简单代码 获取附件核心代码完整代码 介绍一下POP3 介绍 MailKit 是一个开源的 C# 邮件处理库&#xff0c;用于在应用程序中发送和接收电子邮件。它提供了一个强大且易于使…

Redis核心技术与实战【学习笔记】 - 6.Redis 的统计操作处理

1.前言 在 Web 业务场景中&#xff0c;我们经常保存这样一种信息&#xff1a;一个 key 对应了一个数据集合。比如&#xff1a; 手机 APP 中的每天用户登录信息&#xff1a;一天对应一系列用户 ID。电商网站上商品的用户评论列表&#xff1a;一个商品对应了一些列的评论。用户…

【云原生之kubernetes系列】--污点与容忍

污点与容忍 污点&#xff08;taints)&#xff1a;用于node节点排斥Pod调度&#xff0c;与亲和效果相反&#xff0c;即taint的node排斥Pod的创建容忍&#xff08;toleration)&#xff1a;用于Pod容忍Node节点的污点信息&#xff0c;即node节点有污点&#xff0c;也将新的pod创建…

Ubuntu远程连接登录信息解读(ubuntu登录信息、远程登录信息)

文章目录 1. Welcome to Ubuntu 20.04.4 LTS (GNU/Linux 5.4.0-100-generic aarch64)2. 三个链接是官方提供的文档、管理工具和技术支持3. System information as of Thu 01 Feb 2024 03:30:45 PM HKT4. System load: 1.16&#xff1a;系统负载指数5. Processes: 1096系统正在运…

【AI视野·今日Robot 机器人论文速览 第七十七期】Mon, 15 Jan 2024

AI视野今日CS.Robotics 机器人学论文速览 Mon, 15 Jan 2024 Totally 14 papers &#x1f449;上期速览✈更多精彩请移步主页 Daily Robotics Papers Learning Joint Space Reference Manifold for Reliable Physical Assistance Authors Amirreza Razmjoo, Tilen Brecelj, Kri…

【智能家居入门4】(FreeRTOS、MQTT服务器、MQTT协议、微信小程序)

前面已经发了智能家居入门的1、2、3了&#xff0c;在实际开发中一般都会使用到实时操作系统&#xff0c;这里就以FreeRTOS为例子&#xff0c;使用标准库。记录由裸机转到实时操作系统所遇到的问题以及总体流程。相较于裸机&#xff0c;系统实时性强了很多&#xff0c;小程序下发…

Cache Lab:Part B(52.6/53分)【矩阵转置的分块算法】

目录 任务描述 32 32 baseline try1&#xff1a;给对角线上的块再次细分块 try2&#xff1a;对角块依次错位 成功&#xff1a;对角块两两交换 成功&#xff1a;其他方法 64 64 baseline 对角线优化普通块转置顺序调整&#xff08;7.6/8分&#xff09; 61 67 成…

Vue3+vite搭建基础架构(3)--- 使用dayjs

Vue3vite搭建基础架构&#xff08;3&#xff09;--- 使用dayjs 说明官方文档vite.config.js别名配置安装dayjs安装命令 使用dayjs将dayjs封装为自己的日期工具类使用dataUtil.js日期工具类示例 说明 这里记录下自己在Vue3vite的项目使用dayjs的过程&#xff0c;不使用ts语法&a…

最新XC主题 支持六种主题样式 去除域名授权全解密源码 一款多样式主题

Typecho 最新XC主题 去除域名授权全解密源码 这是一款多样式主题&#xff0c;首页支持六种主题样式&#xff0c;支持Pjax优化访问速度&#xff0c;多种单页&#xff0c;如友链、说说等。评论支持表情&#xff0c;自定义编辑器&#xff0c;支持其他样式功能。该主题功能性挺高&…

SQL中的left join和right join及具体实例

LEFT JOIN&#xff08;或称为左连接&#xff09;是SQL中的一种连接类型&#xff0c;它用于从两个或多个表中基于共同的列将数据组合起来。在使用LEFT JOIN时&#xff0c;查询的结果集包含左表&#xff08;LEFT JOIN语句中指定的第一个表&#xff09;的所有记录&#xff0c;以及…

音视频数字化(音频数字化)

在音视频领域,人们始终追求无限还原现场效果,因此音频越逼真越好,视频越清晰越好。之所以我们需要将音视频信号由模拟转为数字,目的是在录制、存储、编辑、复制、回放等环节的不失真,尽量保持原有细节,不因以上操作,导致音画的质量下降。 为此,视频系统分辨率越来越高,…

【Java程序设计】【C00207】基于(JavaWeb+SSM)的宠物领养管理系统(论文+PPT)

基于&#xff08;JavaWebSSM&#xff09;的宠物领养管理系统&#xff08;论文PPT&#xff09; 项目简介项目获取开发环境项目技术运行截图 项目简介 这是一个基于ssm的宠物领养系统 本系统分为前台系统、管理员、收养者和寄养者4个功能模块。 前台系统&#xff1a;游客打开系统…