MySQL:json字段查询:数组、对象、成员检查

本文涉及的产品
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDSClaw,2核4GB
简介: MySQL:json字段查询:数组、对象、成员检查

环境准备

mysql版本


mysql> select version();

+-----------+

| version() |

+-----------+

| 8.0.29    |

+-----------+

1 row in set (0.00 sec)


建表


CREATE TABLE `tb_book` (

 `id` int primary key AUTO_INCREMENT COMMENT '主键id',

 `title` varchar(20) not null COMMENT '书名',

 `persons` json not null COMMENT '主要人物列表',

 `attrs` json not null COMMENT '属性列表',

 `info` json not null COMMENT '详细信息'

) ENGINE=InnoDB COMMENT='图书表';


测试数据


insert into tb_book (title, persons, attrs, info) values (

'红楼梦',

'["贾宝玉", "林黛玉"]',

'[{"label": "朝代", "value": "清代"}]',

'{"author": "曹雪芹"}'

);


insert into tb_book (title, persons, attrs, info) values (

'水浒传',

'["宋江", "李逵"]',

'[{"label": "朝代", "value": "宋代"}]',

'{"author": "施耐庵"}'

);


insert into tb_book (title, persons, attrs, info) values (

'三国演义',

'["曹操", "孙权", "刘备"]',

'[{"label": "朝代", "value": "汉代"}]',

'{"author": "罗贯中"}'

);


insert into tb_book (title, persons, attrs, info) values (

'西游记',

'["孙悟空", "唐僧", "猪八戒", "沙悟净"]',

'[{"label": "朝代", "value": "明代"}]',

'{"author": "吴承恩"}'

);



查看测试数据


mysql> select * from tb_book;

+----+--------------+--------------+---------+-----------+

| id | title  | persons  | attrs  | info  |

+----+--------------+--------------+---------+-----------+

|  1 | 红楼梦  | ["贾宝玉", "林黛玉"]| [{"label": "朝代", "value": "清代"}]| {"author": "曹雪芹"}|

|  2 | 水浒传  | ["宋江", "李逵"]| [{"label": "朝代", "value": "宋代"}]| {"author": "施耐庵"}|

|  3 | 三国演义| ["曹操", "孙权", "刘备"] | [{"label": "朝代", "value": "汉代"}]| {"author": "罗贯中"}|

|  4 | 西游记  | ["孙悟空", "唐僧", "猪八戒", "沙悟净"]| [{"label": "朝代", "value": "明代"}] | {"author": "吴承恩"}|

+----+--------------+--------------+---------+-----------+


查询示例

对象查询


mysql> select id, title, info  from tb_book where info->'$.author' ='吴承恩';


# 或者

mysql> select id, title, info  from tb_book where JSON_EXTRACT(info, '$.author') ='吴承恩';


+----+-----------+-------------------------+

| id | title     | info                    |

+----+-----------+-------------------------+

|  4 | 西游记    | {"author": "吴承恩"}    |

+----+-----------+-------------------------+

1 row in set (0.00 sec)



普通列表查询


mysql> select id, title, persons from tb_book where '宋江' MEMBER OF(persons);

+----+-----------+----------------------+

| id | title     | persons              |

+----+-----------+----------------------+

|  2 | 水浒传    | ["宋江", "李逵"]     |

+----+-----------+----------------------+

1 row in set (0.00 sec)


对象列表查询


mysql> select id, title, attrs from tb_book where JSON_CONTAINS(attrs, JSON_OBJECT('value', '汉代'));

+----+--------------+------------------------------------------+

| id | title        | attrs                                    |

+----+--------------+------------------------------------------+

|  3 | 三国演义     | [{"label": "朝代", "value": "汉代"}]     |

+----+--------------+------------------------------------------+

1 row in set (0.00 sec)



参考

MySQL:JSON字段List成员检查

mysql json类型数据查询

————————————————

版权声明:本文为CSDN博主「彭世瑜」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/mouday/article/details/130812547

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
10月前
|
JSON IDE Java
鸿蒙开发:json转对象插件回来了
首先,我重新编译了插件,进行了上传,大家可以下载最新的安装包进行体验了,还是和以前一样,提供了在线版和IDE插件版,两个选择,最新的版本,除了升级了版本,兼容了最新的DevEco Studio ,还做了一层优化,就是针对嵌套对象和属性的生成,使用方式呢,一年前的文章中有过详细的概述,这里呢也简单介绍一下。
331 4
鸿蒙开发:json转对象插件回来了
|
JSON JavaScript 前端开发
JavaScript实现字符串转json对象的方法
JavaScript实现字符串转json对象的方法
|
前端开发 开发者
如何理解 package.json 中的 proxy 字段?
`package.json` 中的 `proxy` 字段用于配置代理服务器,帮助前端开发中解决跨域问题及模拟后端响应。其基本概念、使用场景及配置方法将在本文中详细探讨,助力开发者高效调试与测试。
526 4
|
JSON Java 数据格式
springboot中表字段映射中设置JSON格式字段映射
springboot中表字段映射中设置JSON格式字段映射
718 1
|
JSON API 数据格式
postman如何发送json请求其中file字段是一个图片
postman如何发送json请求其中file字段是一个图片
717 4
|
JSON 前端开发 JavaScript
json字符串如何转为list对象?
json字符串如何转为list对象?
2218 7
|
JSON JavaScript 前端开发
js如何格式化一个JSON对象?
js如何格式化一个JSON对象?
648 3
|
JSON 前端开发 中间件
React读取properties配置文件转化为json对象并使用在url地址中
本文介绍了如何在React项目中读取properties配置文件,将其内容转化为JSON对象,并在请求URL地址时使用这些配置。文章详细说明了异步读取文件、处理字符串转换为JSON对象的过程,并提供了一个封装函数,用于在发起请求前动态生成配置化的URL地址。
514 1
|
XML JSON JavaScript
JSON对象的stringify()和parse()方法使用
本文阐述了JSON对象的`stringify()`和`parse()`方法的用法,包括如何将JavaScript对象转换为JSON字符串,以及如何将JSON字符串解析回JavaScript对象,并讨论了转换过程中需要注意的事项。
JSON对象的stringify()和parse()方法使用
|
SQL 监控 关系型数据库
MySQL数据库中如何检查一条SQL语句是否被回滚
检查MySQL中的SQL语句是否被回滚需要综合使用日志分析、事务状态监控和事务控制语句。理解和应用这些工具和命令,可以有效地管理和验证数据库事务的执行情况,确保数据的一致性和系统的稳定性。此外,熟悉事务的ACID属性和正确设置事务隔离级别对于预防数据问题和解决事务冲突同样重要。
449 2

推荐镜像

更多