子查询的结果集中不再包含NULL值,因此employee_id NOT IN (...)可以正常比较,返回预期的结果。 总结来说,NOT IN子句在处理包含NULL值的子查询时可能会导致意外的空结果集。为了避免这种情况,通常建议在子查询中排除NULL值,或者使用NOT EXISTS来代替NOT IN,因为NOT EXISTS对NULL值的处理更为直观
从执行结果来看,使用not in非关联子查询,其执行结果与其他两条语句的执行结果还是不同,因为t1.c2 使用not in在参与比较时就隐含了t1.c2 is not null的含义,所以最终结果集中不含(3,NULL)这条数据。 而not exists关联子查询,在将外查询的NULL值传递给内查询时执行子查询select * from t2 where t2.c2=NULL,...
greatsql> insertinto t2 values(,null);再观察一下三条语句的执行结果:greatsql> select * from t1 where t1.c2 notin (select t2.c2 from t2);Empt 结论 使用not in 的非关联子查询注意NULL值对结果集的影响,为避免出现空结果集,需要子查询中查询列加is not null条件将NULL值去除。 实际使用时注意:需...
sql 再not in 子查询有null值的奇怪现象 当我查询的时候明明两张表都有数据,但是用了not in 之后就出问题了!! 这是为什么呢? 原因很简单:由于NULL不能进行如下的“操作” –如果null参与算术运算,则该算术表达式的值为null。(例如:+,-,*,/ 加减乘除) –如果null参与比较运算,则结果可视为false。(例如:>=...
原来是在not in 的时候 NULL 会影响结果集为空的。 selectfrom tableA where tableA.in not in (A,NULL) 相当于selectfrom tableA where tableA.id <> A and tableA.id <> NULL 。 而在ANSI SQL中 <>null 返回的结果永远是0,即没有结果集,且不会提示语法错误。当一个有结果集的数据and一个无结果...
技术人员来评论in 与exists 效率孰高孰低的问题,我在SQL优化工作中也经常对这类子查询做优化改写,比如半连接改为内连接,反连接改为外连接等,哪个效率高是要根据执行计划做出判断的,本文不是为了讨论效率问题,是要提醒一点:not in子查询的结果集含NULL值时,会导致整个语句结果集返回空,这可能造成与SQL语句书写...
技术人员来评论in 与exists 效率孰高孰低的问题,我在SQL优化工作中也经常对这类子查询做优化改写,比如半连接改为内连接,反连接改为外连接等,哪个效率高是要根据执行计划做出判断的,本文不是为了讨论效率问题,是要提醒一点:not in子查询的结果集含NULL值时,会导致整个语句结果集返回空,这可能造成与SQL语句书写...
not in (null) 原因是not in的实现原理是,对每一个和每一个(括号内的查询结果)进行不相等比较(!=) foreach name in table2: if != name: continue else: return false return true 1. 2. 3. 4. 5. 6. 而sql中任意!=null的运算结果都是false,所以如果table2中存在一个null,not in的查询永远都会...
技术人员来评论in 与exists 效率孰高孰低的问题,我在SQL优化工作中也经常对这类子查询做优化改写,比如半连接改为内连接,反连接改为外连接等,哪个效率高是要根据执行计划做出判断的,本文不是为了讨论效率问题,是要提醒一点:not in子查询的结果集含NULL值时,会导致整个语句结果集返回空,这可能造成与SQL语句书写...
如果您使用 SELECT…WHERE x NOT IN(SELECT y FROM…)等“ NOT IN”编写SQL查询,必须了解当“ x”或“ y”为NULL时会发生什么?如果不是您想要的结果,我将在这里告诉您如何解决。 首先,一个简单的情况:如果“ x”和“ y”是使用NOT NULL子句创建的列,则它们永远不会为NULL。让我们考虑其他情况。复杂性源...