觉得不合理是因为觉得null值最终是不符合sql结果会被淘汰的数据,参与hash运算消耗cpu消耗内存多做了无用功。 但是其实由于是表t做驱动表,在这个情景下强制第一个步骤就是对表t做全表扫描,因此是不能自主忽略null值的,原因是,如果not in的表 tt 上应用过滤谓词的结果不包含任何行,那么表t的null值是符合条件的。
SQL01:SELECT * FROM userinfo WHERE age NOT IN(18) SQL01 查询结果里面不会包含 age字段为null 的情况,因为条件的意思翻译为 age<>18, 但是null和任何值比较运算都返回的false, 所以为null的条件行不会被查询出来SQL02:SELECT* FROM userinfo WHERE age NOT IN(18,null) SQL02 不管什么数据,最后的查询结...
通常,含in、exists的子查询称为半连接(semijoin),含not in、 not exists的子查询被称之为反连接,经常会有技术人员来评论in 与exists 效率孰高孰低的问题,我在SQL优化工作中也经常对这类子查询做优化改写,比如半连接改为内连接,反连接改为外连接等,哪个效率高是要根据执行计划做出判断的,本文不是为了讨论效率...
也就是说,如果NOT IN子查询中用到的表里被选择的列中存在NULL,则SQL语句整体的查询结果永远是空。这是很可怕的现象。 为了得到正确的结果,我们需要使用EXISTS谓词。 --正确的SQL语句:拉里和伯杰将被查询到SELECT*FROMClass_AAWHERENOTEXISTS(SELECT*FROMClass_BBWHEREA.age=B.ageANDB.city=’东京’); 结果: n...
NOT IN子句和NULL值 在SQL 查询中,NOT IN 子句用于过滤出不在指定列表中的行。与 IN 子句相反,NOT IN 子句返回不匹配列表中任何值的行。 例如,假设有一个名为 products 的表,其中包含 product_id 和product_name 列。以下查询将返回 product_id 不在列表 [1, 2, 3] 中的所有行: 代码语言:sql 复制 SE...
开发人员写的SQL语句中经常会用到in,exists,not in,not exists 这类子查询,通常,含in、exists的子查询称为半连接(semijoin),含not in、 not exists的子查询被称之为反连接,经常会有技术人员来评论in 与exists 效率孰高孰低的问题,我在SQL优化工作中也经常对这类子查询做优化改写,比如半连接改为内连接,反连...
本文不是为了讨论效率问题,是要提醒一点:not in子查询的结果集含NULL值时,会导致整个语句结果集返回空,这可能造成与SQL语句书写初衷不符。 前言 开发人员写的SQL语句中经常会用到in,exists,not in,not exists 这类子查询,通常,含in、exists的子查询称为半连接(semijoin),含not in、 not exists的子查询被称...
sql 再not in 子查询有null值的奇怪现象 当我查询的时候明明两张表都有数据,但是用了not in 之后就出问题了!! 这是为什么呢? 原因很简单:由于NULL不能进行如下的“操作” –如果null参与算术运算,则该算术表达式的值为null。(例如:+,-,*,/ 加减乘除)...
今天在使用Oracle数据库写存储过程时,发现了一个NOT IN子查询的null值陷阱。看了点资料,大概记录如下。 1、问题记录 本来是要查出A表中col列值在B表col列中没有出现过的记录。实际数据库是有符合条件的记录的,但是,运行如下SQL: Select*FromAwhereA.colnotin(SelectB.colfromB) ...
前言开发人员写的SQL语句中经常会用到in,exists,not in,not exists 这类子查询,通常,含in、exists的子查询称为半连接(semijoin),含not in、 not exists的子查询被称之为反连接,经常会有技术人员来评论in 与exists 效率孰高孰低的问题,我在SQL优化工作中也经常对这类子查询做优化改写,比如半连接改为内连接,...