SQL 某字段值有null,和其他值,想要将所有不等于1的所有行查出来,怎么查询?

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>),好了下面开始说正事:


举例说明:

有个SQL如下:

select * from (
-- 构建临时表
  select 1 a from dual 
  union all
  select 2 a from dual
  union all
  select 3 a from dual
  union all
  select null a from dual
) where a <> 1 -- 重点在这里,为什么查出来的数据只有2、3,null查不出来。

a列的值可能是任何数值或null。

我原本想的是上面的SQL能查询出来a不能于1的所有行(包括null),结果查不出来。

如果将查询条件改为类似:

where case when a is not null then a else -999 end <> 1

查询条件改成上面这种倒是能查询出来,但是会全表扫描一遍,效率很低。

刚刚试了一下PostgreSQL和Oracle都不行,请问怎么能查询出来呢?

###
select * from dual where a is null or a != 1
###

只要是检索null值的,都要走全表

###

这就是为什么需要加索引的字段要设置非null的原因。

郑重声明:本站部分内容转载自网络,版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们(QQ/微信153890879)修改或删除,多谢。