0

0

mysql如何安装JSON支持_mysql 5.7+环境检查

P粉602998670

P粉602998670

发布时间:2026-03-12 12:28:53

|

594人浏览过

|

来源于php中文网

原创

mysql 5.7.8+ 原生支持 json 功能,执行 select json_valid('{"a": 1}'); 返回 1 即表示可用;若报错 function json_valid does not exist,则可能版本过低、误装 mariadb 或使用阉割版二进制。

mysql如何安装json支持_mysql 5.7+环境检查

检查 MySQL 是否已启用 JSON 功能

MySQL 5.7 起原生支持 JSON 类型和相关函数,但前提是编译时启用了 JSON 支持(默认开启),且运行时未被禁用。最直接的验证方式是连上 MySQL 后执行:

SELECT JSON_VALID('{"a": 1}');

如果返回 1,说明 JSON 功能可用;若报错 FUNCTION JSON_VALID does not exist,大概率是 MySQL 版本低于 5.7,或使用了极简版/阉割版二进制(如某些 Alpine Linux 上的 mariadb 替代包)。

  • SELECT VERSION(); 确认版本,5.7.8+ 才有完整 JSON 函数集
  • 检查是否误装了 mariadb:MariaDB 的 JSON 函数名、行为与 MySQL 不兼容(例如用 JSON_EXTRACT 会报错)
  • 某些 Docker 镜像(如 mysql:5.7 官方镜像)默认支持,但自定义构建的镜像可能关闭了 WITH_JSON=OFF

确认 JSON 相关函数是否存在

MySQL 5.7+ 提供约 20 个 JSON 函数,不是所有都默认启用。常见缺失函数包括 JSON_TABLE(MySQL 8.0.4+)、JSON_PRETTY(5.7.22+),但基础函数如 JSON_EXTRACTJSON_SETJSON_CONTAINS 在 5.7.8+ 全支持。

白月生产企业订单管理系统GBK2.0  Build 080807
白月生产企业订单管理系统GBK2.0 Build 080807

请注意以下说明:1、本程序允许任何人免费使用。2、本程序采用PHP+MYSQL架构编写。并且经过ZEND加密,所以运行环境需要有ZEND引擎支持。3、需要售后服务的,请与本作者联系,联系方式见下方。4、本程序还可以与您的网站想整合,可以实现用户在线服务功能,可以让客户管理自己的信息,可以查询自己的订单状况。以及返点信息等相关客户利益的信息。这个功能可提高客户的向心度。安装方法:1、解压本系统,放在

下载
  • 执行 SELECT * FROM INFORMATION_SCHEMA.ROUTINES WHERE ROUTINE_SCHEMA='mysql' AND ROUTINE_NAME LIKE 'json%'; 可列出当前可用 JSON 函数
  • JSON_EXTRACT 都不存在,不是安装问题,而是你根本没在 MySQL 原生环境里——比如连的是 ProxySQL、MaxScale 或旧版中间件,它们可能不透传 JSON 函数
  • JSON_MERGE_PATCHJSON_MERGE_PRESERVE 行为差异大,误用会导致数据覆盖,不是安装问题,但常被当成“JSON 不工作”

常见报错及真实原因

看到 ERROR 3141 (22032): Invalid JSON textInvalid JSON path expression 时,90% 不是 JSON 支持没装好,而是输入格式或路径写错了。

  • JSON_EXTRACT(col, '$.name') 中路径必须用单引号包裹,双引号会报语法错误
  • 插入含中文的 JSON 字符串时,客户端连接字符集不是 utf8mb4 会导致 Invalid JSON text —— 检查 character_set_client 和表字段的 COLLATE
  • LOAD_FILE() 读取 JSON 文件再插入?确保文件路径在 MySQL 服务端可读,且开启了 secure_file_priv 白名单

不需要“安装”,但要避开几个典型陷阱

JSON 支持是 MySQL 内置能力,不是插件,不能通过 INSTALL PLUGIN 加载,也不需要额外扩展包。所谓“安装 JSON 支持”本质是确认环境正确、避免误操作。

  • 别在配置文件里加 plugin-load=json.so —— 这是无效甚至导致启动失败的
  • 别尝试用 apt install mysql-server-json 或类似包名 —— 主流发行版没有这种独立包
  • 升级 MySQL 时若从 5.6 直升 5.7,需运行 mysql_upgrade,否则系统表缺失会导致部分 JSON 函数不可用

真正卡住人的,往往不是 JSON 本身,而是字段定义用 TEXT 存 JSON 字符串却想用 JSON_CONTAINS —— 必须是 JSON 类型字段才能触发类型校验和索引优化。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

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

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

686

2023.06.20

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

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

513

2023.06.21

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

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

287

2023.07.18

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

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

519

2023.07.19

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

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

267

2023.07.25

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

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

392

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

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

542

2023.08.11

mysql忘记密码
mysql忘记密码

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

668

2023.08.14

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

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

精品课程

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

共48课时 | 2.5万人学习

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

共3课时 | 0.3万人学习

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

共1课时 | 847人学习

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

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