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

发布于 2022-09-11 23:32:49 字数 559 浏览 14 评论 0

举例说明:

有个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都不行,请问怎么能查询出来呢?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

固执像三岁 2022-09-18 23:32:49
select * from dual where a is null or a != 1
阳光的暖冬 2022-09-18 23:32:49

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

不可一世的女人 2022-09-18 23:32:49

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

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文