0

0

MySQL中JSON数据类型怎么用_有哪些常用操作技巧?

絕刀狂花

絕刀狂花

发布时间:2025-07-16 09:10:02

|

1182人浏览过

|

来源于php中文网

原创

mysql从5.7开始支持json数据类型,适用于存储配置、标签等半结构化数据。1. 创建表时定义json列;2. 插入合法json字符串;3. 使用->或->>提取字段内容;4. 用json_extract或->操作符做条件筛选;5. 用json_contains查询数组中的值;6. 更新整个或部分json内容可用json_set、json_replace或json_remove函数;7. 对json字段建索引推荐使用虚拟列加索引或mysql 8.0+的json索引方式;json虽灵活但应合理设计,结合常规字段使用效果更佳。

MySQL中JSON数据类型怎么用_有哪些常用操作技巧?

MySQL从5.7版本开始支持JSON数据类型,这让它在处理半结构化数据时更加灵活。如果你需要存储类似配置、标签、嵌套信息等不固定格式的数据,用JSON字段会比传统的多表关联更方便。但怎么用得顺手,还是有些技巧的。

MySQL中JSON数据类型怎么用_有哪些常用操作技巧?

JSON字段的基本使用方式

创建表的时候,可以直接定义一个列的类型为JSON

CREATE TABLE users (
    id INT PRIMARY KEY AUTO_INCREMENT,
    info JSON
);

插入数据时,直接传入合法的JSON字符串即可:

MySQL中JSON数据类型怎么用_有哪些常用操作技巧?
INSERT INTO users (info) VALUES ('{"name": "张三", "age": 28, "tags": ["开发", "阅读"]}');

查询的时候,可以用->操作符提取字段内容:

SELECT info->'$.name' AS name FROM users;

注意:这个提取出来的结果是带引号的字符串,如果要去掉引号,可以加个->>

MySQL中JSON数据类型怎么用_有哪些常用操作技巧?
SELECT info->>'$.name' AS name FROM users;

查询JSON中的特定值

有时候你可能想根据JSON里的某个字段做条件筛选,比如找出所有年龄大于30的用户:

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

或者用更简洁的写法:

SELECT * FROM users WHERE info->'$.age' > 30;

如果你要查数组类型的字段,比如找tags里包含“开发”的记录:

SELECT * FROM users WHERE JSON_CONTAINS(info->'$.tags', '"开发"');

注意里面的值要用双引号包裹,因为JSON标准要求字符串必须用双引号。

易语言学习手册 十天学会易语言图解教程  pdf版
易语言学习手册 十天学会易语言图解教程 pdf版

十天学会易语言图解教程用图解的方式对易语言的使用方法和操作技巧作了生动、系统的讲解。需要的朋友们可以下载看看吧!全书分十章,分十天讲完。 第一章是介绍易语言的安装,以及运行后的界面。同时介绍一个非常简单的小程序,以帮助用户入门学习。最后介绍编程的输入方法,以及一些初学者会遇到的常见问题。第二章将接触一些具体的问题,如怎样编写一个1+2等于几的程序,并了解变量的概念,变量的有效范围,数据类型等知识。其后,您将跟着本书,编写一个自己的MP3播放器,认识窗口、按钮、编辑框三个常用组件。以认识命令及事件子程序。第

下载

修改JSON字段的内容

更新整个JSON内容很简单,直接赋新值就行:

UPDATE users SET info = '{"name": "李四", "age": 32}' WHERE id = 1;

但如果只想修改其中某个字段,推荐用JSON_SETJSON_REPLACEJSON_REMOVE函数:

  • JSON_SET:添加或更新字段
  • JSON_REPLACE:只替换已有字段
  • JSON_REMOVE:删除字段

举个例子,给id=1的用户增加一个地址字段:

UPDATE users SET info = JSON_SET(info, '$.address', '北京') WHERE id = 1;

索引优化JSON查询性能(重点)

默认情况下,对JSON字段内的值做查询是不能走索引的,效率会比较低。解决办法有两个:

  • 创建虚拟列(Generated Column)并为其建立索引
  • 使用JSON索引(MySQL 8.0+ 支持)

以虚拟列为例子:

ALTER TABLE users ADD COLUMN name VARCHAR(100) GENERATED ALWAYS AS (info->>'$.name') STORED;
CREATE INDEX idx_name ON users(name);

这样以后按名字查询就能走索引了。

如果是MySQL 8.0以上版本,还可以直接建索引:

CREATE INDEX idx_age ON users((CAST(info->'$.age' AS UNSIGNED)));

不过这种写法稍显复杂,也容易出错,建议优先考虑虚拟列的方式。


基本上就这些。JSON类型虽然好用,但别滥用,尤其不要把整个表都设计成一个大JSON字段。适当结合常规字段和JSON结构,才能发挥最大优势。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

661

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

245

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

281

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

514

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

253

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

528

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

599

2023.08.14

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

0

2026.01.14

热门下载

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

精品课程

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

共48课时 | 1.7万人学习

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

共3课时 | 0.3万人学习

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

共1课时 | 787人学习

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

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