MySQL JSON NULL查询

最近遇到个奇葩问题,查询MySQL表A里的一个字段content,字段数据是json格式的,格式类似下面这种:

python 复制代码
{
	"errorCode": "SVCSTG.ALS.200.200",
	"errorMessage": "Report success.",
	"result": null
}
sql 复制代码
select  JSON_EXTRACT(content,'$.result') as a from A where a<> NULL ;

查询不出result字段为null的数据,然后使用json_type()函数看下字段的数据类型

sql 复制代码
select  JSON_TYPE(JSON_EXTRACT(content,'$.result')) as a from A where a<> NULL ;

查询结果显示确实是NULL,那就见鬼了!然后检查了字段是否包含空格,空串结果还是排除不掉null的数据然后使用

sql 复制代码
select  JSON_TYPE(JSON_EXTRACT(content,'$.result')) as a from A where a!= 'null'
and a!='' and a IS NOT NULL;

查询的结果还是有null数据,然后突发奇想查查result值为null的数据呢?

sql 复制代码
select  JSON_TYPE(JSON_EXTRACT(content,'$.result')) as a from A where a IS NULL ;

查询结果显示查询出的数据不包含result字段,因此可以断定JSON_TYPE中的NULL数据类型和MySQL中的NULL不是一回事,最后试了下<>'NULL'才凑效

sql 复制代码
select  JSON_TYPE(JSON_EXTRACT(content,'$.result')) as a from A where a<> 'NULL' ;

这个sql查询出的结果才是理想的数据~

结论:MySQL中的字段中json串中字段的null值等价于字符串"NULL",坑爹啊

相关推荐
德育处主任Pro14 分钟前
在亚马逊云上解决RDS、MariaDB 与 Aurora MySQL复制延迟实战指南
数据库·mysql·mariadb
Cat God 00743 分钟前
基于 CentOS 7.6 的 MySQL 8.0 主从复制
linux·服务器·mysql·centos
笨蛋少年派1 小时前
Maxwell数据变更捕获工具简介
数据库·mysql
邂逅星河浪漫1 小时前
【MySQL 事务】详细介绍+实例
数据库·mysql·事务
云和数据.ChenGuang2 小时前
OpenEuler 系统中安装 MySQL
运维·数据库·mysql·adb·运维工程师·运维技术
莫叫石榴姐2 小时前
ast 在 Dify 工作流中解析 JSON 格式数据的深度解析
大数据·网络·安全·json
GDAL2 小时前
express.json 深入全面讲解教程
json·express
风月歌2 小时前
基于微信小程序的学习资料销售平台源代码(源码+文档+数据库)
java·数据库·mysql·微信小程序·小程序·毕业设计·源码
gjc5922 小时前
【一次线上 MySQL 死锁问题的完整复盘与解析】
数据库·mysql·死锁
qq2439201612 小时前
mysql导致的内存泄漏Abandoned connection cleanup thread
数据库·mysql