MySQL中GROUP_CONCAT与JSON_OBJECT、GROUP BY的巧妙结合:打造高效JSON数组汇总

在数据库操作中,经常遇到需要将同一组内的多行数据汇总为一个结构化的输出,特别是在处理一对多关系时。MySQL 5.7及以上版本引入了对JSON的支持,使得这一过程变得更加灵活和高效。本文将以一个实例深入探讨如何利用GROUP_CONCAT结合JSON_OBJECTGROUP BY来实现这一需求,具体场景是将delivery_id相同的所有产品信息合并为一个JSON数组。

背景介绍

想象一下,你管理着一个电商物流系统数据库,其中delivery_order_product表存储了每个配送订单的产品详情。每个订单可能包含多个商品条目,每条记录对应一个商品。目标是为每个delivery_id生成一个JSON数组,汇总其所有产品的详细信息。

技术要点

1. JSON_OBJECT函数

  • 功能:此函数用于创建一个JSON格式的对象,接受一系列键值对作为参数。
  • 语法JSON_OBJECT(key1, value1, key2, value2, ...)

2. GROUP_CONCAT函数

  • 功能:将多行数据合并成一个字符串,每行之间可自定义分隔符。
  • 语法GROUP_CONCAT(column_name ORDER BY column_name SEPARATOR separator)

3. GROUP BY子句

  • 功能:用于将查询结果按照一列或多列进行分组,这里是按delivery_id分组。

实现步骤

SQL示例

考虑以下SQL查询,它展示了如何将delivery_order_product表中的数据,根据delivery_id分组,并将每个组内的产品信息构造成JSON对象,最后合并为一个JSON数组。

SELECT delivery_id,GROUP_CONCAT(JSON_OBJECT('creator', creator,'creatorId', creator_id,'createTime', DATE_FORMAT(create_time, '%Y-%m-%dT%H:%i:%S+08:00'),'updater', updater,'updaterId', updater_id,'updateTime', DATE_FORMAT(update_time, '%Y-%m-%dT%H:%i:%S+08:00'),'enabledFlag', enabled_flag,'traceId', trace_id,'deliveryId', delivery_id,'productSku', product_sku,'productName', product_name,'productCount', product_count,'productImg', product_img,'productStandard', product_standard,'productCategory', product_category,'unitVolumn', unit_volumn,'unitWeight', unit_weight,'deliveredCount', delivered_count,'waitDeliveryCount', wait_delivery_count,'sourceOrderNo', source_order_no,'productBrand', product_brand,'unitMeasurement', unit_measurement,'goodsField1', goods_field_1,'goodsField2', goods_field_2,'goodsField3', goods_field_3,'id', id)SEPARATOR ',') AS json
FROM delivery_order_product
GROUP BY delivery_id;

解析

  • JSON_OBJECT:为每个产品创建一个JSON对象,包括了产品详情的所有字段。
  • GROUP_CONCAT:以逗号为分隔符,将同一delivery_id下的所有JSON对象合并为一个字符串,形成JSON数组的形式。
  • GROUP BY delivery_id:确保操作基于每个独特的delivery_id执行,每个delivery_id对应的结果集中只包含其自己的产品列表。

结果与应用

执行上述查询后,你会获得一个结果集,每行代表一个唯一的delivery_id,其json列包含了一个JSON数组,数组内是该订单所有产品的详细信息。这种格式非常适合于直接传输给前端应用,或者用于API响应,无需额外处理即可被JavaScript等客户端语言解析和操作。

小结

通过MySQL的GROUP_CONCATJSON_OBJECT的组合,配合GROUP BY子句,我们可以高效地将数据库中的一对多关系数据转换为结构化的JSON格式,大大简化了后端到前端的数据传递过程,提高了系统的灵活性和响应速度。这一技巧在处理复杂数据汇总场景时尤为有效,是现代Web应用开发中不可或缺的数据库操作技能。

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

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

相关文章

C#里如何设置输出路径,不要net7.0-windows

官网介绍&#xff1a; 更改生成输出目录 - Visual Studio (Windows) | Microsoft Learn <PropertyGroup> <AppendTargetFrameworkToOutputPath>false</AppendTargetFrameworkToOutputPath> <AppendRuntimeIdentifierToOutputPath>false</Appen…

面试题: malloc与new的区别

malloc, free是C语言中的库函数&#xff0c; new, delete是C中的运算符new自动计算分配内存的大小&#xff0c;malloc需要手动计算分配内存的大小new返回对象类型的指针&#xff0c;malloc返回的是void*类型&#xff0c;需要显式类型转换new分配失败抛出异常&#xff0c;malloc…

大数据Scala教程从入门到精通第四篇:Scala语言特点

一&#xff1a;Scala语言特点 Scala是一门头Java虚拟机(JVM)为运行环境并将面向对象和函数式编程的最佳特性结合在一起的静态类型编程语言(静态语言需要提前编译的如:Java、c、c等&#xff0c;动态语言如:js) 1)&#xff1a;Scala是一门多范式的编程语言&#xff0c;Scala支持…

[COCI2022-2023#1] Berilij 题解

推荐在 cnblogs 上阅读。 Solution P9030 [COCI2022-2023#1] Berilij 本题解转载翻译自官方题解&#xff1a;COCI 2022/2023 CONTEST 1 Part 1 让我们定义图形 G G G&#xff0c;顶点代表飞船&#xff0c;边代表两艘飞船外部接触的情况。此外&#xff0c;让边的边权成为它…

AI大模型程序员小白入门 - 关于如何更好地学习算法

关于本书 本项目旨在打造一本开源免费、新手友好的数据结构与算法入门教程。 全书采用动画图解,内容清晰易懂、学习曲线平滑,引导初学者探索数据结构与算法的知识地图。源代码可一键运行,帮助读者在练习中提升编程技能,了解算法工作原理和数据结构底层实现。提倡读者互助学…

git bash各分支修改内容不同但合并后不显示冲突问题

在跟着廖雪峰老师的git学习时&#xff0c;按部就班的执行明后&#xff0c;发现 而不是出现原文的结果 解决方法&#xff1a; 切换位feature分支&#xff0c;再合并 git switch feature1 git merge master 此时我们发现&#xff1a; 后面再跟着原文敲就可以了

双指针类型解题汇总

1 最接近的三数之和 给定一个包括 n 个整数的数组 nums 和 一个目标值 target。找出 nums 中的三个整数&#xff0c;使得它们的和与 target 最接近。返回这三个数的和。假定每组输入只存在唯一答案。 示例&#xff1a;输入&#xff1a;nums [-1,2,1,-4], target 1 输出&am…

每日一题5:Pandas-修改列

一、每日一题 一家公司决定增加员工的薪水。 编写一个解决方案&#xff0c;将每个员工的薪水乘以2来 修改 salary 列。 返回结果格式如下示例所示。 解答&#xff1a; import pandas as pddef modifySalaryColumn(employees: pd.DataFrame) -> pd.DataFrame:employees.loc[…

如何更好地使用Kafka? - 故障时解决

要确保Kafka在使用过程中的稳定性&#xff0c;需要从kafka在业务中的使用周期进行依次保障。主要可以分为&#xff1a;事先预防&#xff08;通过规范的使用、开发&#xff0c;预防问题产生&#xff09;、运行时监控&#xff08;保障集群稳定&#xff0c;出问题能及时发现&#…

Databend 开源周报第 143 期

Databend 是一款现代云数仓。专为弹性和高效设计&#xff0c;为您的大规模分析需求保驾护航。自由且开源。即刻体验云服务&#xff1a;https://app.databend.cn 。 Whats On In Databend 探索 Databend 本周新进展&#xff0c;遇到更贴近你心意的 Databend 。 了解 Databend …

Redis学习(十)|使用消息队列的重试机制实现 MySQL 和 Redis 的数据一致性

文章目录 介绍原理整体方案实现步骤示例代码总结其他&#xff1a;Kafka 重试策略配置1. 生产者重试策略配置2. 消费者重试策略配置 介绍 在分布式系统中&#xff0c;保持 MySQL 和 Redis 之间的数据一致性是至关重要的。为了确保数据的一致性&#xff0c;我们通常采取先更新数…

去中心化金融与Web3:科技驱动的金融革命

随着区块链技术的发展和普及&#xff0c;去中心化金融&#xff08;DeFi&#xff09;作为其重要应用之一&#xff0c;正在成为金融领域的一场革命。结合Web3技术&#xff0c;去中心化金融正在以前所未有的方式重新定义着金融服务和产品的交付方式&#xff0c;推动着金融领域的创…

bfs之八数码

文章目录 八数码解题思路图解举例算法思路 代码CPP代码Java代码 八数码 在一个 33的网格中&#xff0c;1∼8这 8个数字和一个 x 恰好不重不漏地分布在这 33 的网格中。 例如&#xff1a; 1 2 3 x 4 6 7 5 8在游戏过程中&#xff0c;可以把 x 与其上、下、左、右四个方向之一…

【Oracle】Linux x86-64 安装Oracle 23AI指南

本文为云贝教育 刘峰 原创&#xff0c;请尊重知识产权&#xff0c;转发请注明出处&#xff0c;不接受任何抄袭、演绎和未经注明出处的转载。 前言 在信息技术日新月异的今天&#xff0c;企业级数据库系统扮演着数据管理与业务支撑的核心角色。Oracle数据库&#xff0c;作为全球…

IAP15W4K61S4单片机EEPROM读写程序

/*-------------关闭IAP----------------*/ void IapIdle() { IAP_CONTR 0; //关闭IAP功能 IAP_CMD 0; //清除命令寄存器 IAP_TRIG 0; …

专业软件测试会议

全国软件测试会议&#xff1a;这是一个系列性的专业会议&#xff0c;由中国的学术机构或专业组织主办&#xff0c;例如中国计算机学会的容错计算专业委员会。此会议自2005年起开始举办&#xff0c;历届会议地点包括北京、昆明和武汉等地。会议内容覆盖软件测试理论、实践、工具…

跟TED演讲学英文:4 pillars of college success in science by Freeman Hrabowski

4 pillars of college success in science Link: https://www.ted.com/talks/freeman_hrabowski_4_pillars_of_college_success_in_science Speaker: Freeman Hrabowski Date: February 2013 文章目录 4 pillars of college success in scienceIntroductionVocabularyTranscr…

uniapp打包的程序在Xcode中运行到模拟器报错的解决方法

uniapp打包的程序在Xcode中运行到模拟器报错的解决方法 问题描述&#xff1a; Building for iOS-simulator, but linking in object file (/Users/hori/Documents/SDK/SDK/Libs/DCUniRecord.framework/DCUniRecord[arm64][3](PGRecord.o)) built for iOS Linker command fail…

Day 25 数据库查询

数据库查询 一&#xff1a;基本查询 1.简介 ​ 单表查询 ​ 简单查询 ​ 通过条件查询 ​ 查询排序 ​ 限制查询记录数 ​ 使用集合函数查询 ​ 分组查询 ​ 使用正则表达式查询 2.案例 创建案例所需表&#xff1a;company.employee5 雇员编号 id int雇…

ISIS的工作原理

1.邻居关系建立 &#xff08;1&#xff09;IS-IS领接关系建立原则 1、通过将以太网接口模拟成点到点接口&#xff0c;可以建立点到点链路邻接关系。 2、当链路两端IS-IS接口的地址不在同一网段时&#xff0c;如果配置接口对接收的Hello报文不作IP地址检查&#xff0c;也可以建…