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",坑爹啊

相关推荐
流㶡1 小时前
mysql学习笔记之创建表、导入导出数据
数据库·mysql
shejizuopin3 小时前
基于SSM的高校旧书交易系统的设计与实现(任务书)
java·mysql·毕业设计·论文·任务书·基于ssm的·高校旧书交易系统的设计与实现
Wiktok3 小时前
SQLAlchemy+PyMySQL的实用实战示例
python·mysql·sqlalchemy
不想写bug呀3 小时前
MySQL事务介绍
数据库·mysql
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.3 小时前
双主模式实现HTTP与MySQL高可用
网络协议·mysql·http
cheems95273 小时前
【MySQL】SQL调优:数据库性能优化(一)
数据库·sql·mysql
qq_297574674 小时前
MySQL迁移到瀚高数据库 常用转换函数对照表(附XML示例,直接复用)
xml·数据库·mysql
Mr_Xuhhh4 小时前
MySQL复合查询详解:多表查询、子查询与合并查询
数据库·sql·mysql
奔跑的呱呱牛4 小时前
geojson-to-kml (KML 格式转换工具)
arcgis·json
Big Cole4 小时前
PHP 面试:MySQL 核心问题之索引与优化
mysql·面试·php