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.youkuaiyun.com/minshiwang/article/details/130769571

### MySQLJSON 字段的操作方法 在 MySQL 中,JSON 类型字段允许存储结构化的 JSON 数据。通过内置的函数可以方便地查询、修改和操作这些数据。以下是关于如何查询 JSON 字段的具体方法。 #### 查询 JSON 字段的内容 如果需要提取 JSON 字段中的某个键值,可以使用 `->` 或者 `->>` 运算符。 - `->` 返回的是 JSON 格式的字符串。 - `->>` 则会自动解析并返回纯文本形式的结果。 示例代码如下: ```sql -- 假设有一张表 `users`,其中包含一个名为 `profile` 的 JSON 字段 SELECT profile->'$.name' AS name_json_format, profile->>'$.name' AS name_text_format FROM users; ``` 上述语句中,`profile->'$.name'` 将返回 JSON 格式的名称[^4],而 `profile->>'$.name'` 则直接返回纯文本格式的名字。 #### 条件过滤基于 JSON 字段的数据 可以通过 JSON 提取器结合条件表达式实现复杂查询。例如: ```sql SELECT * FROM users WHERE JSON_EXTRACT(profile, '$.age') > 30; ``` 此查询将筛选出 `profile` 字段中年龄大于 30 的记录。注意这里使用了 `JSON_EXTRACT()` 函数来获取指定路径下的值。 另外一种更简洁的方式是利用箭头运算符完成相同功能: ```sql SELECT * FROM users WHERE profile->'$."age"' > 30; ``` 两种写法效果一致,但后者语法更加直观易读。 #### 更新 JSON 字段内的特定值 除了查询外,还可以更新 JSON 对象内部节点的数值。下面展示了一个例子说明怎样改变某条记录里 JSON 数据的一部分内容。 ```sql UPDATE users SET profile = JSON_SET(profile, '$.email', 'new.email@example.com') WHERE id = 1; ``` 这条命令把 ID 为 1 用户资料里的电子邮箱地址替换成了新的值。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值