NOTIN之后的子查询为什么不能包含NULL值

本篇内容主要讲解“NOT IN之后的子查询为什么不能包含NULL值”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“NOT IN之后的子查询为什么不能包含NULL值”吧!

十载的镇安网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。营销型网站的优势是能够根据用户设备显示端的尺寸不同,自动调整镇安建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。创新互联建站从事“镇安网站设计”,“镇安网站推广”以来,每个客户项目都认真落实执行。

如果空值可能是子查询结果的一部分,则不应与主查询中的NOT IN运算符一起使用。为什么呢?看下面例子就明白了。

NOT IN后面的子查询有记录为NULL,主查询查不到记录

select * from emp where 3 not in (1, 2, null);

未选定行

因为这个查询可以理解为

select * from emp where 3 <> 1 and 3 <> 2 and 3 <> null;

由于NULL值不能参与比较运算符,导致条件不成立,因此查询不出来数据。

如果是IN运算则能查到数据

select * from emp where 1 in (1, 2, null);

NOT IN之后的子查询为什么不能包含NULL值

因为可将该查询理解为

select * from emp where 1 = 1 or 1 = 2 or 1 = null;

虽然NULL值同样不能做比较,但或运算的短路效应使得前面条件已成立时全盘条件即成立,因此输出了结果。

到此,相信大家对“NOT IN之后的子查询为什么不能包含NULL值”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


分享标题:NOTIN之后的子查询为什么不能包含NULL值
本文地址:http://scjbc.cn/article/goooes.html

其他资讯