我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL多行合并--GROUP_CONCAT函数,转换json数组--JSON_ARRAY() 函数,转换json对象--json_object()函数

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL多行合并--GROUP_CONCAT函数,转换json数组--JSON_ARRAY() 函数,转换json对象--json_object()函数

GROUP_CONCAT: 多行合并

在表设计中,一个字段可能会对应多条数据,但在有的查询场景下,需要实现将多行数据合并成一行数据,在MySQL中可以使用GROUP_CONCAT函数来实现

id

pid

name

2

1

篮球

3

1

足球

正常查出来是两条数据,如果需要一条,就可以用GROUP_CONCAT

GROUP_CONCAT(field1)这样默认就是一个字段用逗号拼接

select pid ,GROUP_CONCAT(name) from table,结果就是

pid

name

1

篮球,足球

GROUP_CONCAT(field1,'-',field2)这样默认就是两个个字段用-拼接

select pid ,GROUP_CONCAT(id,'-',name) from table,结果就是

pid

name

1

2-篮球,3-足球

json_object: 创建Json对象

如果要将查出来的字段转换成json对象,可以用这个函数:JSON_OBJECT('id',id,'name',name)

select pid ,JSON_OBJECT('id',id,'name',name) from table,结果就是

pid

name

1

{"id": 2, "name": "篮球"}

1

{"aid": 3, "name": "足球"}

json_array:创建Json数组

如果要将查出来的字段转换成json数组,可以用这个函数:json_array(id,name)

select pid ,JSON_ARRAY(id,name) from table,结果就是

pid

name

1

[2, "篮球"]

1

[3, "足球"]

这就是最简单的使用方法了,当然了,大家可以继续深化使用,

比如JSON_ARRAY(JSON_OBJECT('id',id,'name',name) )

比如 GROUP_CONCAT(JSON_OBJECT('id',id,'name',name))

等等

放一个例子:

select `key`, json_array(GROUP_CONCAT(JSON_OBJECT('name', name, 'aid', aid,'preview_address',preview_address,'whether_receive',whether_receive,'free_or_not',free_or_not)))  as res from (SELECT 'templateList' as `key`,aid,template_name as `name`,preview_address ,whether_receive,free_or_not from (SELECT * FROM lb_free_template_material ORDER BY create_time DESC LIMIT 12) t1union allSELECT 'stickerList' as `key`,aid,sticker_name as `name`,preview_address ,whether_receive,free_or_not from (SELECT * FROM lb_free_sticker_material ORDER BY create_time DESC LIMIT 12) t2  union allSELECT 'fontList' as `key`,aid,font_name as `name`,preview_address ,whether_receive,free_or_not from (SELECT * FROM lb_free_font_material ORDER BY create_time DESC LIMIT 12) t3   union allSELECT 'brushList' as `key`,aid,brush_name as `name`,preview_address ,whether_receive,free_or_not from (SELECT * FROM lb_free_brush_material ORDER BY create_time DESC LIMIT 12) t4    union allSELECT 'dynamicList' as `key`,aid,dynamic_effect_name as `name`,preview_address ,whether_receive,free_or_not from (SELECT * FROM lb_free_dynamic_material ORDER BY create_time DESC LIMIT 12) t5   union allSELECT 'backgroundList' as `key`,aid,background_name as `name`,preview_address ,whether_receive,free_or_not from (SELECT * FROM lb_free_background_material ORDER BY create_time DESC LIMIT 12) t6   ) t group by  `key`;

来源地址:https://blog.csdn.net/zlfjavahome/article/details/129533187

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL多行合并--GROUP_CONCAT函数,转换json数组--JSON_ARRAY() 函数,转换json对象--json_object()函数

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

使用PHP的json_encode()函数将数组或对象转换为JSON字符串

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,已经成为Web应用程序之间数据交换的常用格式。PHP的json_encode()函数可以将数组或对象转换为JSON字符串。本文将介绍如何使用PHP的
使用PHP的json_encode()函数将数组或对象转换为JSON字符串
2023-11-03

如何将函数指针转换为函数对象并反之?

在 c++++ 中,通过 std::function 模板可将函数指针转换为函数对象:使用 std::function 将函数指针包装成函数对象。使用 std::function::target 成员函数将函数对象转换为函数指针。此转换在事
如何将函数指针转换为函数对象并反之?
2024-04-18

使用PHP的json_encode()函数将数组或对象转换为JSON字符串并格式化输出

使用PHP的json_encode()函数将数组或对象转换为JSON字符串并格式化输出,可以让数据在不同的平台和语言之间进行传递和交换变得更加容易。本文将介绍json_encode()函数的基本用法,以及如何将JSON字符串格式化输出。一、
使用PHP的json_encode()函数将数组或对象转换为JSON字符串并格式化输出
2023-11-03

使用PHP的json_decode()函数将JSON字符串转换为数组或对象并处理解析错误

使用PHP的json_decode()函数将JSON字符串转换为数组或对象并处理解析错误在PHP开发中,经常会遇到需要将JSON字符串转换为数组或对象的情况,而PHP提供了一个非常方便的函数json_decode()来实现这个功能。不过,当
使用PHP的json_decode()函数将JSON字符串转换为数组或对象并处理解析错误
2023-11-03

使用PHP的json_encode()函数将数组或对象转换为格式化后的JSON字符串

使用PHP的json_encode()函数将数组或对象转换为格式化后的JSON字符串在PHP开发中,经常需要将数组或对象转换为JSON字符串,以便进行数据的传输或存储。PHP提供了json_encode()函数,可以方便地将数组或对象转换为
使用PHP的json_encode()函数将数组或对象转换为格式化后的JSON字符串
2023-11-03

使用PHP的json_encode()函数将数组或对象转换为JSON字符串并将中文字符编码为UTF-8

使用PHP的json_encode()函数将数组或对象转换为JSON字符串并将中文字符编码为UTF-8在PHP中,我们可以使用json_encode()函数将一个数组或对象转换为JSON字符串。默认情况下,json_encode()函数将中
使用PHP的json_encode()函数将数组或对象转换为JSON字符串并将中文字符编码为UTF-8
2023-11-03

如何使用 STL 函数对象来进行数据验证和转换?

使用 stl 函数对象可简化数据验证和转换。验证函数对象返回布尔值,表示数据是否有效;转换函数对象返回新值。这些函数对象可应用于数据容器,实现数据验证和转换,例如验证是否大于 10 并将大于 10 的数字加倍。使用 STL 函数对象进行数据
如何使用 STL 函数对象来进行数据验证和转换?
2024-04-25

编程热搜

目录