mysql json字段存储的是 [1,2,3] 如何查询

以下是针对MySQL中[1,2,3]类型JSON数组字段的查询方法总结,涵盖常见场景和语法:

一、检查数组是否包含特定值

使用JSON_CONTAINS函数‌
查询数组中是否包含数字2:


SELECT * FROM 表名 WHERE JSON_CONTAINS(json字段, '2', '$');
-- 等效简写:WHERE json字段->'$' LIKE '%2%'


'$'表示根路径(整个数组),'2'需为有效的JSON标量值(字符串需加引号)。

多值联合查询‌
检查同时包含1和3:


SELECT * FROM 表名 
WHERE JSON_CONTAINS(json字段, '1', '$') 
  AND JSON_CONTAINS(json字段, '3', '$');


不支持直接传递多值参数。

二、搜索数组中的字符串

使用JSON_SEARCH定位元素位置(返回路径或NULL):


-- 查询包含字符串"abc"的数组
SELECT * FROM 表名 
WHERE JSON_SEARCH(json字段, 'one', 'abc') IS NOT NULL;

'one':找到第一个匹配即停止;'all'返回所有匹配路径。
三、精确匹配整个数组

直接比较JSON文档(严格匹配顺序和格式):


SELECT * FROM 表名 
WHERE json字段 = '[1,2,3]';  -- JSON文档需完全一致


注意空格和元素顺序差异会导致匹配失败。

四、查询数组长度

使用JSON_LENGTH函数:


SELECT JSON_LENGTH(json字段) AS 数组长度 FROM 表名;
-- 示例:筛选长度≥3的数组
SELECT * FROM 表名 WHERE JSON_LENGTH(json字段) >= 3;


适用于统计或条件过滤。

五、提取数组元素

按索引获取值(索引从0开始):


-- 提取第一个元素
SELECT JSON_EXTRACT(json字段, '$[0]') AS 首元素 FROM 表名;
-- 简写:SELECT json字段->'$[0]'


路径表达式$[n]指定索引位置。

六、复杂查询(MySQL 8.0+)

使用JSON_TABLE将数组转为临时表:


SELECT j.* 
FROM 表名, 
JSON_TABLE(
  json字段,
  '$[*]' COLUMNS (
    元素值 INT PATH '$'
  )
) AS j
WHERE j.元素值 = 2;  -- 筛选元素值=2的行


适合对数组元素执行关联查询或聚合操作。

注意事项
索引优化‌:对JSON字段创建虚拟列并加索引可加速查询。
浮点数处理‌:JSON中的数字类型可能被转换为DOUBLE,比较时需注意精度问题。
路径表达式‌:键名含特殊字符时需用['key']格式(如$[0]['name'])。

以上方法适用于MySQL 5.7及以上版本,部分高级功能(如JSON_TABLE)需8.0+支持。

### 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
发出的红包

打赏作者

luoluosheng07

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值