0

0

MySQL如何查询和筛选存储的JSON数据?

PHPz

PHPz

发布时间:2023-07-12 13:43:36

|

2688人浏览过

|

来源于php中文网

原创

mysql如何查询和筛选存储的json数据?

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,在现代应用程序中得到了广泛的应用。MySQL从5.7版本开始添加了对JSON的支持,使得我们可以在MySQL数据库中存储和查询JSON格式的数据。本文将介绍如何使用MySQL查询和筛选存储的JSON数据,并提供相应的代码示例。

  1. 创建测试表和插入数据

首先,我们需要创建一个测试表,并插入一些包含JSON数据的示例数据。下面是一个名为"users"的表的定义:

CREATE TABLE users (
    id INT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(50) NOT NULL,
    info JSON
);

INSERT INTO users (name, info) VALUES
    ('John', '{"age": 30, "city": "New York", "email": "john@example.com"}'),
    ('Alice', '{"age": 25, "city": "Los Angeles", "email": "alice@example.com"}'),
    ('Bob', '{"age": 35, "city": "Chicago", "email": "bob@example.com"}');

在上面的示例中,"users"表包含三个字段:id,name和info。其中,info字段的数据类型为JSON。

  1. 查询JSON字段中的属性值

要查询JSON字段中的属性值,可以使用MySQL提供的JSON_EXTRACT函数。下面是一个示例:

SELECT name, JSON_EXTRACT(info, '$.age') AS age FROM users;

上述查询将返回每个用户的姓名和年龄信息。其中,JSON_EXTRACT函数的第一个参数为要查询的JSON字段,第二个参数为要提取的属性路径。在这个示例中,我们提取了info字段中的age属性。

  1. 使用WHERE条件筛选JSON数据

在MySQL中,我们可以使用WHERE条件来筛选JSON数据。下面是一个示例:

SELECT name, info
FROM users
WHERE JSON_EXTRACT(info, '$.age') > 30;

上述查询将返回所有年龄大于30岁的用户的姓名和JSON数据。可以看到,我们可以使用JSON_EXTRACT函数获取JSON字段中的属性值,并在WHERE条件中使用这些属性值进行筛选。

PHP Apache和MySQL 网页开发初步
PHP Apache和MySQL 网页开发初步

本书全面介绍PHP脚本语言和MySOL数据库这两种目前最流行的开源软件,主要包括PHP和MySQL基本概念、PHP扩展与应用库、日期和时间功能、PHP数据对象扩展、PHP的mysqli扩展、MySQL 5的存储例程、解发器和视图等。本书帮助读者学习PHP编程语言和MySQL数据库服务器的最佳实践,了解如何创建数据库驱动的动态Web应用程序。

下载
  1. 更新JSON字段中的属性值

要更新JSON字段中的属性值,可以使用MySQL提供的JSON_SET函数。下面是一个示例:

UPDATE users
SET info = JSON_SET(info, '$.city', 'Seattle')
WHERE name = 'Alice';

上述更新操作将把名字为"Alice"的用户的城市信息修改为"Seattle"。JSON_SET函数的第一个参数为要更新的JSON字段,第二个参数为要修改的属性路径,第三个参数为新的属性值。

  1. 删除JSON字段中的属性值

要删除JSON字段中的属性值,可以使用MySQL提供的JSON_REMOVE函数。下面是一个示例:

UPDATE users
SET info = JSON_REMOVE(info, '$.email')
WHERE name = 'Bob';

上述更新操作将删除名字为"Bob"的用户的邮件地址属性。JSON_REMOVE函数的第一个参数为要删除属性的JSON字段,第二个参数为要删除的属性路径。

结论

本文介绍了如何使用MySQL查询和筛选存储的JSON数据,并提供了相应的代码示例。通过使用JSON_EXTRACT函数,我们可以方便地获取JSON字段中的属性值;而使用JSON_SET和JSON_REMOVE函数,我们可以进行属性值的更新和删除操作。使用MySQL存储和操作JSON数据,可以更好地满足现代应用程序的需求。

相关专题

更多
ip地址修改教程大全
ip地址修改教程大全

本专题整合了ip地址修改教程大全,阅读下面的文章自行寻找合适的解决教程。

33

2025.12.26

压缩文件加密教程汇总
压缩文件加密教程汇总

本专题整合了压缩文件加密教程,阅读专题下面的文章了解更多详细教程。

18

2025.12.26

wifi无ip分配
wifi无ip分配

本专题整合了wifi无ip分配相关教程,阅读专题下面的文章了解更多详细教程。

46

2025.12.26

漫蛙漫画入口网址
漫蛙漫画入口网址

本专题整合了漫蛙入口网址大全,阅读下面的文章领取更多入口。

91

2025.12.26

b站看视频入口合集
b站看视频入口合集

本专题整合了b站哔哩哔哩相关入口合集,阅读下面的文章查看更多入口。

283

2025.12.26

俄罗斯搜索引擎yandex入口汇总
俄罗斯搜索引擎yandex入口汇总

本专题整合了俄罗斯搜索引擎yandex相关入口合集,阅读下面的文章查看更多入口。

370

2025.12.26

虚拟号码教程汇总
虚拟号码教程汇总

本专题整合了虚拟号码接收验证码相关教程,阅读下面的文章了解更多详细操作。

35

2025.12.25

错误代码dns_probe_possible
错误代码dns_probe_possible

本专题整合了电脑无法打开网页显示错误代码dns_probe_possible解决方法,阅读专题下面的文章了解更多处理方案。

25

2025.12.25

网页undefined啥意思
网页undefined啥意思

本专题整合了undefined相关内容,阅读下面的文章了解更多详细内容。后续继续更新。

72

2025.12.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 774人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号