记一次Oracle数据库in语句事故

1、前情介绍

有个数据处理的活比较着急,从同事的代码中拷贝了一段SQL语句,其中,包含如下的语句:

SELECT *
FROM a
WHERE col IN
    (SELECT col
     FROM b
     WHERE b_col=col_val)

这段sql并不难懂,就是返回a表中col的值满足in子句中查询条件的结果。但是,我在实际中遇到的情况是,这个in子句一直不生效,这个语句也不报错。查了半天,最后发现b表没有名为col的列。

2、原因分析

如果b表没有col列时,这个语句就相当于:

SELECT *
FROM a
WHERE 'a' IN
    (SELECT 'a'
     FROM b
     WHERE b_col=col_val)

只要子查询能够查会结果,这个in子句就会返回true。这样,就导致了这个筛选条件实际不生效。而且,并不报错,在实际中特别不好分析。

3、场景复现

为了复现这个场景,这里用如下的表结构和数据:

CREATE TABLE Persons
(
Name varchar(255),
Address varchar(255)
);
INSERT INTO Persons VALUES ('Bill Gates', 'Beijing');
INSERT INTO Persons VALUES ('Kobe Byrant', 'Los Angeles');
CREATE TABLE Citys
(
CityName varchar(255),
ZipCode varchar(255)
);
INSERT INTO Citys VALUES ('Beijing', '010');

当执行如下查询:

SELECT *
FROM persons
WHERE Name IN
    (SELECT Name
     FROM citys
     WHERE zipCode='010')

得到结果:

NAME ADDRESS
Bill Gates Beijing
Kobe Byrant Los Angeles

而在执行如下查询时,查不到结果:

SELECT *
FROM persons
WHERE Name IN
    (SELECT Name
     FROM citys
     WHERE zipCode='251718')

4、写在最后

这种问题,在学校那会儿,肯定有一大堆语料强调过。然而,这种问题,不结结实实被坑一次,应该不会长记性。
接下来,推荐两个SQL在线测试的网站:

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 转 # https://www.cnblogs.com/easypass/archive/2010/12/ 08/...
    吕品㗊阅读 10,142评论 0 44
  • ORA-00001: 违反唯一约束条件 (.) 错误说明:当在唯一索引所对应的列上键入重复值时,会触发此异常。 O...
    我想起个好名字阅读 5,990评论 0 9
  • 第一天 7月13日OCP笔记: Oracle Ocp11g准备资料: OracleFundmentals 书 管理...
    fjxCode阅读 2,889评论 0 4
  • 我刚刚听王源唱那首《明天过后》时发现,他将麦克风从麦架上拔下来的那个动作,很温柔。 王源到底是个什么样的人呢。 我...
    一碗甜夏阅读 234评论 0 1
  • 常言道:“夜路走多了,总会碰见鬼的。”宋七月总是希望这是真的,然而她从小到大走过数不清的漆黑夜晚,也不曾和一只孤魂...
    元宵Mochi阅读 597评论 0 0

友情链接更多精彩内容