MySQL中关于NULL值的六大坑!你被坑过吗?

NULL值是我们在开发过程中的老朋友了,但是这个老朋友在MySQL中有很多坑,我通过这篇文章来总结分享一下,欢迎大家在评论区分享你的看法和踩坑经历。

1、NULL不等于NULL

在MySQL中,执行以下SQL会返回NULL

假如t表有以下数据,其中有一条a为null的记录

如果执行以下SQL将会返回空集合,明明有a为null的记录,但却没查到,好坑!

假如我们认为NULL等于NULL,那么这就会导致误解,从而导致业务逻辑出现问题。

大家觉得:NULL应不应该等于NULL呢?

事实上,我们得通过is null来判断某个值是不是null,可为啥要这么设计呢?

2、NULL与任何值比较都为NULL

实际上,NULL与任何值比较都为NULL

这里的重点是,并不是返回的0,而是null,既然不相等,为什么不返回0呢?不是1代表相等,0代表不相等吗?好坑!

3、NULL导致唯一索引不唯一

我们给a、b两个字段创建唯一联合索引

sql 复制代码
alter table t add unique idx_ab(a,b);

由于是唯一索引,所以第二次插入(1,1)时会报错

sql 复制代码
insert into t(a,b) values(1,1);
insert into t(a,b) values(1,1);

但如果是插入(2,null)则不会报错

sql 复制代码
insert into t(a,b) values(2,null);
insert into t(a,b) values(2,null);

最终表中的结果为

不是说ab是唯一索引吗,怎么还能有重复记录?好坑!

4、NULL对排序的影响

当前表的数据为

我们对a字段先进行升序排序

嗯...NULL排在了最前面,两个NULL也按id进行了升序排序,这倒是能理解,那反过来进行降序排序呢

嗯...NULL排在了最后面,这倒没问题,可是两个NULL的记录能不能也按id进行降序排序呢?你觉得是坑吗?

5、聚合函数不会统计NULL值

对于上表,总共有8条记录,其中a为null的有两条,执行count语句,以下结果大家应该能理解,count(a)时不会统计a为null的记录。

但是如果对a字段执行求平均数,那么结果为4.1667

计算方法为8+6+5+3+2+1=25,然后25/6=4.1667,关键是,到底应该是25/6还是25/8呢?你们觉得呢?

6、NULL导致函数结果为NULL

有时,我们可能会在SQL进行字符串连接,比如执行

为什么要返回null呢?返回'daduduzhouyu'应该更好吧?

欢迎大家在评论区聊聊你对这六大坑的看法,或者自己的踩坑经历,谢谢大家的阅读,记得点赞、关注哦。

我的所有文章汇总在了我的公众号:IT周瑜,欢迎大家关注,同时公众号内还有我整理的100道面试真题,有需要的兄弟关注后即可领取。

相关推荐
万少2 分钟前
万少的 Claude Code 入门教程
前端·人工智能·后端
malog_5 分钟前
Milvus向量数据库:AI时代的搜索革命
数据库·人工智能·后端·milvus
胡耀超16 分钟前
《设计数据密集型应用》(DDIA, 2nd ed.) 心智模型导览——《Designing Data-Intensive Applications》书介绍导航
大数据·数据库·分布式·ai·架构·数据
invicinble20 分钟前
springboot提供的机制大全
java·spring boot·后端
ai安歌23 分钟前
鸿蒙PC:Qt适配OpenHarmony实战【人名录】:单机联系人卡片,不读系统通讯录也能演示详情联动
数据库·qt·harmonyos
夏贰四24 分钟前
数据库管理有哪些核心要点?数据库管理该如何规范落地?
大数据·数据库·数据库管理·数据库管理员
zhangxingchao25 分钟前
AI 大模型面试核心二:微调、RAG、MCP、Agent 与工程落地
前端·人工智能·后端
IT策士27 分钟前
Django 从 0 到 1 打造完整电商平台:商品搜索
后端·python·django
zhangxingchao27 分钟前
AI 大模型面试核心三: RAG、Agent 到 Prompt Engineering 的工程化理解
前端·人工智能·后端
Hilaku29 分钟前
从 15MB 减到 800KB,一行 ffmpeg 解决3D 渲染卡顿问题
前端·javascript·程序员