Mysql

关注公众号 jb51net

关闭
首页 > 数据库 > Mysql > mysql匹配JSON中的某个字段

mysql如何匹配JSON中的某个字段

作者:佛天华

在MySQL数据库中,可以通过JSON_EXTRACT函数或->>运算符查询JSON类型字段内特定键的值,例如,使用JSON_EXTRACT(data, '$.name')或data->>'$.name'从data字段中提取name键的值,并用于比较得到name为"张三"的记录

mysql匹配JSON中的某个字段

表中有一个字段,它的类型是JSON,我想要匹配这个JSON串中的某个字段的值

在 MySQL 中,如果某个字段是 JSON 类型,并且你需要查询 JSON 数据中 name 等于 "张三" 的所有记录,

可以使用JSON_EXTRACT函数或 ->> 运算符来提取 JSON 数据中的值,然后在 WHERE 子句中进行过滤。

假设你有一个表 users,其中有一个字段 data 是 JSON 类型,并且 JSON 数据的结构如下:

{
    "name": "张三",
    "age": 30
}

你可以使用以下两种方法来查询 name 为 “张三” 的记录。

方法 1: 使用 JSON_EXTRACT

SELECT * 
FROM users 
WHERE JSON_EXTRACT(data, '$.name') = '张三';

方法 2: 使用 ->> 运算符

SELECT * 
FROM users 
WHERE data->>'$.name' = '张三';

解释

JSON_EXTRACT(data, '$.name'):从 JSON 字段 data 中提取 name 的值。

->> '$.name':这是 MySQL 的简化语法,用于直接提取 JSON 中的某个键的值,并以字符串形式返回。

注意:

示例数据和查询

CREATE TABLE users (
    id INT AUTO_INCREMENT PRIMARY KEY,
    data JSON
);
INSERT INTO users (data) VALUES
('{"name": "张三", "age": 30}'),
('{"name": "李四", "age": 25}'),
('{"name": "王五", "age": 28}');
SELECT * 
FROM users 
WHERE data->>'$.name' = '张三';

这个查询将返回第一条记录。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文