mysql 匹配JSON中的某个字段

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

在 MySQL 中,如果某个字段是 JSON 类型,并且你需要查询 JSON 数据中 name 等于 "张三" 的所有记录,可以使用JSON_EXTRACT函数或 ->> 运算符来提取 JSON 数据中的值,然后在 WHERE 子句中进行过滤。

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

json 复制代码
{
    "name": "张三",
    "age": 30
}

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

方法 1: 使用 JSON_EXTRACT

sql 复制代码
SELECT * 
FROM users 
WHERE JSON_EXTRACT(data, '$.name') = '张三';

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

sql 复制代码
SELECT * 
FROM users 
WHERE data->>'$.name' = '张三';

解释

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

注意

这两种方法返回的值都是字符串,因此在 WHERE 子句中直接比较即可。

如果 name 键不总是存在或者存在多个相同的键(例如一个数组中的对象),则需要根据具体的 JSON 结构调整查询条件。

示例数据和查询

假设表 users 的结构如下:

sql 复制代码
CREATE TABLE users (
    id INT AUTO_INCREMENT PRIMARY KEY,
    data JSON
);

插入一些示例数据:

sql 复制代码
INSERT INTO users (data) VALUES
('{"name": "张三", "age": 30}'),
('{"name": "李四", "age": 25}'),
('{"name": "王五", "age": 28}');

查询 name 为 "张三" 的记录:

sql 复制代码
SELECT * 
FROM users 
WHERE data->>'$.name' = '张三';

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

相关推荐
Promise微笑28 分钟前
Geo专家于磊:Json-LD优化实战SOP与双核四驱体系
大数据·人工智能·重构·json
专注VB编程开发20年31 分钟前
json和python元组,列表,字典对比
开发语言·python·json·php
qq_2975746737 分钟前
MySQL核心技术实战系列(第二篇):MySQL核心基础:库与表的增删改查(CRUD)实战
数据库·mysql
Irene19911 小时前
SQL示例:明辨窗口函数和聚合函数的使用和选择
mysql·oracle
数据库小学妹1 小时前
CDC实时数据同步:让数据库变更秒级流向大数据平台!
大数据·数据库·mysql·kafka·dba
XZ-0700011 小时前
MySQL-视图
数据库·mysql
C137的本贾尼1 小时前
查询进阶:排序、过滤与分页
数据库·mysql
青云计划2 小时前
MySQL技术文档
java·mysql
奇树谦2 小时前
深度解析 compile_commands.json:源码到目标码映射的核心枢纽
json
qq_297574672 小时前
MySQL核心技术实战系列(第一篇):MySQL零基础入门:安装、配置与客户端工具使用 一、前言
数据库·mysql·adb