mysql not in 丢失数据

mysql not in 丢失数据,第1张

all_student表是所有的学生信息,fail_student表是不及格的学生信息

select * from all_student

select * from fail_student

查询及格的学生信息

select * from all_student

where name not in (

select name from fail_student

)

假如fail_student有一条name为null的记录

再次查询及格的学生信息,结果集为空

select * from all_student

where name not in (

select name from fail_student

)

解决方案

1.修改表结构,设置name字段为not null,并设置默认值

2.修改sql为

select * from all_student a

left join fail_student f on a.name = f.name

where f.name is null

这个问题的根源在于null。

众所周知,当判断一个值是否为null的时候,sql要用is null 或者is not null, 在SQL中,Null值并不是一个值,而是表示特定含义,其所表示的含义是“Unknow”,可以理解为未定义或者未知,因此任何与Null值进行比对的二元 *** 作符结果一定为Null,包括Null值本身。

解决:


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7475438.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-06
下一篇 2023-04-06

发表评论

登录后才能评论

评论列表(0条)

保存