欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 文旅 > 八卦 > MySQL中json类型数据查询

MySQL中json类型数据查询

2025/3/9 10:01:14 来源:https://blog.csdn.net/m0_74823292/article/details/146050065  浏览:    关键词:MySQL中json类型数据查询

公司的一个电商系统,索引字段中,需要存储某个spu下挂的所有sku基本信息,数据库字段设计成json类型。为了平时查询数据方便,需要了解一些json相关的函数,网上找了各种资料,但没有一篇比较完整且经过验证的的文章,所以熬夜整理了一份,现在分享给友友们。

mysql在5.7版本之后就开始支持json数据类型,并且mysql8.0版本对json的处理已经做的非常完善了。json数据类型的优点缺点可自己查询,本文主要介绍一些关于json数据类型的查询操作。

准备数据

准备DDL

CREATE TABLE `users` (??`id` int unsigned NOT NULL AUTO_INCREMENT,??`name` varchar(255) NOT NULL COMMENT '姓名',??`address` json NOT NULL COMMENT '住址',??PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;

准备DML

INSERT INTO `users` VALUES (1, '张三', '{"city": "石家庄市", "tags": ["家", "公司"], "district": "桥西区", "province": "河北省"}');
INSERT INTO `users` VALUES (2, '李四', '{"city": "广州市", "tags": ["宿舍"], "district": "珠海区", "province": "广州省"}');
INSERT INTO `users` VALUES (3, '王五', '{"city": "长春市", "district": "绿园区", "province": "吉林省"}');
INSERT INTO `users` VALUES (4, '刘六', '{"city": "昌平区", "province": "北京市"}');
INSERT INTO `users` VALUES (5, '张三三', '[{"city": "石家庄市", "tags": ["家", "公司", "学校"], "district": "桥西区", "province": "河北省"}, {"city": "郑州市", "tags": ["宿舍"], "district": "桥东区", "province": "河南省"}]');
INSERT INTO `users` VALUES (6, '李四四', '[{"city": "广州市", "tags": ["宿舍"], "district": "珠海区", "province": "广州省"}, {"city": "广州市", "district": "珠海区", "province": "广州省"}]');
INSERT INTO `users` VALUES (7, '王五六', '["家", "公司", "学校"]');

查询json对象指定属性值的数据

1、函数查询:json_extract(json字段, ‘$.json属性’)

select * from users where json_extract(address, ‘$.province’) = “河北省”;

2、对象操作方法进行查询:json字段->‘$.json属性’

select * from users where address->‘$.province’ = “河北省”;

查询json数组指定下标值的数据

1、数组操作方式查询:字段->‘$[0]’

select * from users where address->‘$[0]’= “家”;

根据JSON对象里面的属性个数查询

1、函数查询:json_length(json字段)

select * from users where json_length(address) = 2;

根据JSON数组里面的数组长度查询

1、函数查询:json_length(json字段)

select * from users where json_length(address) = 2;

根据JSON对象属性值为数组的数组长度查询

1、函数查询:json_length(json字段, ‘$.json属性’)

#获取addresss里面tags数组长度为2的数据

select * from users where json_length(address, ‘$.tags’) = 2;

查询JSON对象属性值为数组的任意项存在指定值查询

1、函数查询:JSON_CONTAINS(json字段,JSON_OBJECT(‘json数组属性’, ‘内容’))

select * from users where JSON_CONTAINS(address,JSON_OBJECT(‘tags’, ‘家’));

查询JSON数组里面对象属性任意项存在指定属性的数据

select * from users where address->‘$[*].city’ is not null;

查询JSON对象存在指定属性的数据

select * from users where address->‘$.tags’ is not null;

转载:msw;原文链接:https://blog.csdn.net/minshiwang/article/details/130769571

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词