MySQL中类似PostgreSQL中的string_agg函数--GROUP_CONCAT函数的使用

文章目录

    • 结论:MySQL没有string_agg,但有GROUP_CONCAT
    • GROUP_CONCAT函数的基本用法
      • 示例
      • 注意事项
    • 系统变量 group_concat_max_len 如何查看和设置
      • 查看当前的`group_concat_max_len`值
      • 设置`group_concat_max_len`值
    • 相关源码
    • 相关链接


结论:MySQL没有string_agg,但有GROUP_CONCAT

MySQL中没有直接等同于PostgreSQL的string_agg函数的内置函数,但你可以使用GROUP_CONCAT函数来实现类似的功能。GROUP_CONCAT函数可以将多个行的字符串值连接成一个字符串,类似于string_agg

GROUP_CONCAT函数的基本用法

GROUP_CONCAT函数的基本语法如下:

GROUP_CONCAT([DISTINCT] expr [,expr,...] [ORDER BY expr [ASC | DESC]] [SEPARATOR separator])
  • expr:要连接的表达式。
  • DISTINCT:可选,用于指定在连接字符串之前删除重复值。
  • ORDER BY:可选,用于指定连接字符串中值的顺序。
  • SEPARATOR:可选,用于指定连接字符串中值之间的分隔符,默认为逗号。

示例

假设你有一个名为employees的表,其中包含namedepartment列。你可以使用GROUP_CONCAT函数来获取每个部门的所有员工姓名,如下所示:

SELECT department, GROUP_CONCAT(name ORDER BY name ASC SEPARATOR ', ') AS employees
FROM employees
GROUP BY department;

这个查询将返回每个部门及其所有员工的姓名,员工姓名按字母顺序排列,并以逗号和空格分隔。

注意事项

  • GROUP_CONCAT函数的结果是一个字符串,因此它的长度有限制。默认情况下,这个限制是1024个字符,但你可以通过设置group_concat_max_len系统变量来增加这个限制。
  • GROUP_CONCAT函数在MySQL 5.7及更高版本中可用。如果你使用的是MySQL 5.6或更早版本,你可能需要使用其他方法来实现类似的功能。

系统变量 group_concat_max_len 如何查看和设置

在MySQL中,group_concat_max_len是一个系统变量,用于控制GROUP_CONCAT函数返回的结果字符串的最大长度。你可以使用SHOW VARIABLES语句来查看当前的group_concat_max_len值,并使用SET语句来设置新的值。

查看当前的group_concat_max_len

要查看当前的group_concat_max_len值,可以使用以下SQL语句:

SHOW VARIABLES LIKE 'group_concat_max_len';

这将返回group_concat_max_len的当前值。

设置group_concat_max_len

要设置group_concat_max_len的值,可以使用以下SQL语句:

SET [GLOBAL | SESSION] group_concat_max_len = new_value;
  • GLOBAL:用于设置全局值,这将对所有新的客户端连接生效。
  • SESSION:用于设置会话值,这仅对当前客户端连接生效。
    例如,要将group_concat_max_len设置为1000000,可以使用以下SQL语句:
SET GLOBAL group_concat_max_len = 1000000;

或者,仅对当前会话设置:

SET SESSION group_concat_max_len = 1000000;

请注意,增加group_concat_max_len的值可能会导致内存使用量增加,因此在设置较大的值时需要谨慎。

相关源码

判断结果长度的相关源码:sql/item_sum.cc

Item_func_group_concat::add()

调用 dump_leaf_key(table->record[0] + table->s->null_bytes, 1, this);

即:int dump_leaf_key(void *key_arg, element_count count [[maybe_unused]],void *item_arg)

其中dump_leaf_key函数中的关键判断代码如下(正常返回0,异常返回1):

int dump_leaf_key(void *key_arg, element_count count [[maybe_unused]],void *item_arg) {……/*Stop if the size of group_concat value, in bytes, is longer thanthe maximum size.*/if (result->length() > item->group_concat_max_len) {int well_formed_error;const CHARSET_INFO *cs = item->collation.collation;const char *ptr = result->ptr();size_t add_length;/*It's ok to use item->result.length() as the fourth argumentas this is never used to limit the length of the data.Cut is done with the third argument.*/add_length = cs->cset->well_formed_len(cs, ptr + old_length, ptr + item->group_concat_max_len,result->length(), &well_formed_error);result->length(old_length + add_length);item->warning_for_row = true;push_warning_printf(current_thd, Sql_condition::SL_WARNING, ER_CUT_VALUE_GROUP_CONCAT,ER_THD(current_thd, ER_CUT_VALUE_GROUP_CONCAT), item->row_count);/**To avoid duplicated warnings in Item_func_group_concat::val_str()*/if (table && table->blob_storage)table->blob_storage->set_truncated_value(false);return 1;}return 0;
}

相关链接

官方文档:https://dev.mysql.com/doc/refman/8.0/en/aggregate-functions.html#function_group-concat

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

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

相关文章

基于Django以及vue的电子商城系统设计与实现

基于Django以及vue的电子商城系统设计与实现 引言 随着电子商务的快速发展,越来越多的企业和个人选择搭建线上商城,以提供更加便捷的购物体验。本文基于Python开发了一套电子商城系统,后端采用Django框架,前端使用Vue.js&#x…

用语言模型探索语音风格空间:无需情感标签的情 感TTS

用语言模型探索语音风格空间:无需情感标签的情感TTS 原文:Exploring speech style spaces with language models: Emotional TTS without emotion labels 今天我们要说的是 一种无需情感标签的情感TTS。提出了一个基于FastSpeech2的E-TTS框架&#xff0…

Linux网络编程--Udp套接字+实战 (万字详解,超详细!!)

目录 套接字协议: 协议(protocol): 创建套接字(Create Socket): 绑定服务器地址 开始通信 Udp服务器设计--V1 Udp服务器设计--V2 引入进程池 待更新 套接字协议: 协议(protocol): 如果2个距离很远的人想要进行交流&#xff…

C# 两种方案实现调用 DeepSeek API

目录 序 开发运行环境 访问API的一个通用方法 原生官网实现 申请 API key 调用实现 调用示例 腾讯云知识引擎原子调用 申请 API key 调用示例 小结 序 DeepSeek(深度求索) 最近可谓火爆的一塌糊涂,具体的介绍这里不再赘述&#x…

中间件-安装Minio-集成使用(ubantu-docker)

目录 1、安装docer 2、运行以下命令拉取MinIO的Docker镜像 3、检查当前所有Docker下载的镜像 4、创建目录 5、创建Minio容器并运行 6、SDK操作 FileUploader.java 1、安装docer 参考这篇:Linux安装Docker 2、运行以下命令拉取MinIO的Docker镜像 docker pull…

LabVIEW用户界面设计原则

在LabVIEW开发中,用户界面(UI)设计不仅仅是为了美观,它直接关系到用户的操作效率和体验。一个直观、简洁、易于使用的界面能够大大提升软件的可用性,尤其是在复杂的实验或工业应用中。设计良好的UI能够减少操作错误&am…

使用 Docker 安装 Open WebUI 并集成 Ollama 的 DeepSeek 模型

文章目录 使用 Docker 安装 Open WebUI 并集成 Ollama 的 DeepSeek 模型前提条件1. 安装ollama2. 拉取deepseek的模型3. Open-WebUI 说明4. 启动容器文档的方法如下优化命令(可选)1. 增加了健康检查机制(--health-cmd)2. 使 WebUI…

19.4.9 数据库方式操作Excel

版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。 本节所说的操作Excel操作是讲如何把Excel作为数据库来操作。 通过COM来操作Excel操作,请参看第21.2节 在第19.3.4节【…

算法15(力扣347)——前k个高频元素

1、问题 给你一个整数数组 nums 和一个整数 k ,请你返回其中出现频率前 k 高的元素。你可以按 任意顺序 返回答案。 2、示例 (1) 输入: nums [1,1,1,2,2,3], k 2 输出: [1,2] (2) 输入: nums [1], k 1 输出: [1…

防御保护-----前言

HCIE安全防御 前言 计算机病毒 ​ 蠕虫病毒----->具备蠕虫特性的病毒:1,繁殖性特别强(自我繁殖);2,具备破坏性 蠕虫病毒是一种常见的计算机病毒,其名称来源于它的传播方式类似于自然界中…

IntelliJ IDEA 2024.1.4版无Tomcat配置

IntelliJ IDEA 2024.1.4 (Ultimate Edition) 安装完成后,调试项目发现找不到Tomcat服务: 按照常规操作添加,发现服务插件中没有Tomcat。。。 解决方法 1、找到IDE设置窗口 2、点击Plugins按钮,进入插件窗口,搜索T…

docker compose部署flink集群

本次部署2个jobmanager和3个taskmanager 一、部署zookeeper集群 flink使用zookeeper用作高可用 部署集群参考:docker compose部署zookeeper集群-CSDN博客 二、创建目录及配置文件 创建timezone文件,内容填写Asia/Shanghai 手动创建目录&#xff1a…

XSS 常用标签及绕过姿势总结

XSS 常用标签及绕过姿势总结 一、xss 常见标签语句 0x01. 标签 <a href"javascript:alert(1)">test</a> <a href"x" onfocus"alert(xss);" autofocus"">xss</a> <a href"x" onclickeval(&quo…

【Django】 templates模板与static静态文件

1.templates模板 在app01(你创建的app名称)文件夹下&#xff0c;创建templates文件夹&#xff0c;其中存放想要返回的html文件 对应关系如下 除了上面的方式&#xff0c;还可以在项目根目录下创建templates文件夹&#xff0c;这时需要在settings.py文件中增加一行代码&#xf…

解锁电商数据宝藏:淘宝商品详情API实战指南

在电商蓬勃发展的今天&#xff0c;数据已成为驱动业务增长的核心引擎。对于商家、开发者以及数据分析师而言&#xff0c;获取精准、实时的商品数据至关重要。而淘宝&#xff0c;作为国内最大的电商平台&#xff0c;其海量商品数据更是蕴含着巨大的价值。 本文将带你深入探索淘…

YOLO11 【二】 【速通 训练+推理+导出】

一、 vscode 配置 conda 环境 选择默认配置修改配置文件 %windir%\System32\cmd.exe “/K” D:\Software\Anaconda3\Scripts\activate.bat D:\Software\Anaconda3 将该命令加到配置文件后面 ** “/K” D:\Software\Anaconda3\Scripts\activate.bat D:\Software\Anaconda3 **…

UWB功耗大数据插桩调研

一、摘要 UWB功耗点 插桩点 日志关键字 电流 蓝牙持锁 BatteryStats的锁统计 vendor_bluetooth_lock 30~40mA 测距 UwbSessionManager.startRanging UwbSessionManager.stoptRanging 或接入fadiKey Uwb状态广播 "com.fadiui.dkservice.action.uwb.state.change&q…

开发完的小程序如何分包

好几次了&#xff0c;终于想起来写个笔记记一下 我最开始并不会给小程序分包&#xff0c;然后我就各种搜&#xff0c;发现讲的基本上都是开发之前的小程序分包&#xff0c;可是我都开发完要发布了&#xff0c;提示我说主包太大需要分包&#xff0c;所以我就不会了。。。 好了…

前端vue项目打包部署

一、打包 可以在vscode中输入命令打包&#xff0c;也可以通过vscode的图形化界面打包 打包完成后&#xff0c;目录中&#xff0c;会生成dist文件。打包后&#xff0c;数据占用空间更小&#xff0c;比如把换行都去掉了。 完成打包 二、部署 前端主流部署服务器是 Ngix &#x…

PyTorch 中 `torch.cuda.amp` 相关警告的解决方法

在最近的写代码过程中&#xff0c;遇到了两个与 PyTorch 的混合精度训练相关的警告信息。这里随手记录一下。 警告内容 警告 1: torch.cuda.amp.autocast FutureWarning: torch.cuda.amp.autocast(args...) is deprecated. Please use torch.amp.autocast(cuda, args...) i…