首页 > 代码库 > 【问题】和NULL比较遇到的问题
【问题】和NULL比较遇到的问题
1、问题描述:
1 select FName from teacher 2 where FId not in(3 select distinct FTeacherId from student4 )
子查询返回的结果集中包含NULL,导致整条查询语句执行失败。
2、原因:
当和NULL比较(比如a=NULL、a<>NULL),返回结果总是UNKNOWN,所以整条语句执行失败。
如果把"ansi_nulls"设置为"off"(不推荐使用),那么比较结果会是TRUE或者FALSE,这样语句就能执行成功。
1 a not in(1,2,NULL)2 相当于3 a<>1 and a<>2 and a<>NULL
a<>NULL结果为"UNKONWN",导致整条语句执行失败
3、解决方法:
加上不为空的限定
1 select distinct FTeacherId from student where FTeacherId<>NULL
【问题】和NULL比较遇到的问题
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。