首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

LEFT Outer join +where子句意外结果

LEFT OUTER JOIN是一种关系型数据库中的连接操作,它返回左表中的所有记录以及右表中与左表匹配的记录。WHERE子句用于筛选满足特定条件的记录。在某些情况下,使用LEFT OUTER JOIN和WHERE子句可能会导致意外的结果。

具体来说,当使用LEFT OUTER JOIN时,如果在WHERE子句中对右表进行筛选,可能会导致左表中的某些记录被排除在结果集之外。这是因为WHERE子句在LEFT OUTER JOIN之后执行,它会对连接后的结果进行筛选,包括左表和右表的记录。

举个例子,假设有两个表A和B,它们通过某个字段进行连接。使用LEFT OUTER JOIN可以获取A表中的所有记录以及与之匹配的B表记录。然而,如果在WHERE子句中对B表的某个字段进行筛选,那么只有满足条件的B表记录会被包含在结果集中,而A表中对应的记录可能会被排除在外。

为了避免这种意外结果,可以将对右表的筛选条件移至LEFT OUTER JOIN的ON子句中。这样,筛选条件会在连接操作之前应用于右表,确保左表中的所有记录都能正确匹配到右表。

总结起来,LEFT OUTER JOIN和WHERE子句的组合可能导致意外结果,需要注意筛选条件的位置。在使用LEFT OUTER JOIN时,建议将对右表的筛选条件放在ON子句中,以确保结果集包含左表中的所有记录和满足条件的右表记录。

腾讯云提供了一系列云计算相关的产品,包括云数据库、云服务器、云原生应用引擎等。具体针对LEFT OUTER JOIN和WHERE子句的意外结果,腾讯云没有特定的产品或文档进行推荐。但可以参考腾讯云的数据库产品(https://cloud.tencent.com/product/cdb)和服务器产品(https://cloud.tencent.com/product/cvm)来满足云计算中的数据库和服务器需求。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

left join on and 与 left join on where的区别

在使用left jion时,on和where条件的区别如下: 1、 on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录。...2、where条件是在临时表生成好后,再对临时表进行过滤的条件。这时已经没有left join的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉。        ...join tab2 on (tab1.size = tab2.size) where tab2.name=’AAA’ 2、select * formtab1 left join tab2 on (tab1...left join,right join,full join的特殊性,不管on上的条件是否为真都会返回left或right表中的记录,full则具有left和right的特性的并集。...而inner jion没这个特殊性,则条件放在on中和where中,返回的结果集是相同的。

1.2K20
  • Hive的left joinleft outer joinleft semi join三者的区别

    join测试数据 hive left join测试数据 测试1:left join 语句: select * from table1 left outer join table2 on(table1....‘join’ ‘table2’ in join type specifie 我用的HIVE版本是0.8,不支持直接的left join写法; 测试2:left outer join 语句: select...* from table1 left outer join table2 on(table1.student_no=table2.student_no); 结果: 1 name1 1 11 1 name1...结论: hive不支持’left join’的写法; hive的left outer join:如果右边有多行和左边表对应,就每一行都映射输出;如果右边没有行与左边行对应,就输出左边行,右边表字段为NULL...; hive的left semi join:相当于SQL的in语句,比如上面测试3的语句相当于“select * from table1 where table1.student_no in (table2

    2.8K70

    inner joinouter join、right joinleft join 之间的区别

    一、sql的left join 、right join 、inner join之间的区别   left join(左联接) 返回包括左表中的所有记录和右表中联结字段相等的记录    right join...(右联接) 返回包括右表中的所有记录和左表中联结字段相等的记录   inner join(等值连接) 只返回两个表中联结字段相等的行        outer join(外连接) 可分为左外连接left...join sql语句如下:  select * from A left join B  on A.aID = B.bID 结果如下: aID     aNum     bID     bName...---------- 4.outer join left joinleft outer join 的简写,两者含义一样的。...select * from dept left outer join employee on dept.deptid=employee.deptid 或者:select * from dept ,employee

    4.6K30

    Hive的left joinleft outer joinleft semi join三者的区别

    join测试数据 测试1:left join 语句: select * from table1 left outer join table2 on(table1.student_no=table2...join type specifier 我用的HIVE版本是0.8,不支持直接的left join写法; 测试2:left outer join 语句: select * from table1...left outer join table2 on(table1.student_no=table2.student_no); 结果: 1 name1 1 11 1 name1 1 12 1 name1...结论: hive不支持’left join’的写法; hive的left outer join:如果右边有多行和左边表对应,就每一行都映射输出;如果右边没有行与左边行对应,就输出左边行,右边表字段为...NULL; hive的left semi join:相当于SQL的in语句,比如上面测试3的语句相当于“select * from table1 where table1.student_no in (

    3.9K50

    left join-on-and 与 left join-on-where 和 inner join on 加条件和where加条件的区别

    摘要 关于这两种写法的重要知识点摘要如下: left-join 时,即使有相同的查询条件,二者的查询结果集也不同,原因是优先级导致的,on 的优先级比 where 高 on-and 是进行韦恩运算连接生成临时表时使用的条件...where则是在生成临时表之后使用的条件,此时已经不管是否使用了left join了,只要条件不为真的行,全部过滤掉。 在多表查询时,on 比 where 更早起作用。...u.age>20; 执行结果: (2)执行 left-join-on-where 写法SQL select u.name,u.age,s.scorefrom tb_user u left join...写法会先对右表同时做2个条件的过滤 写法 left-join-on-where 在连表查询过程中先根据 on 条件过滤右表,再执行 join 操作生成临时表,然后对临时表执行 where 条件, 因此...,on-where 写法会先对右表做1个条件的过滤,然后对 join 后的结果再执行1个条件的过滤 由于 on 优先级比 where 更高,执行时机会更早,因此,理论上来说 on-and 写法比 on-where

    2.3K30

    SQL 查询条件放到 JOIN 子句WHERE 子句的差别

    我们再写 SQL 的时候,最常碰到一个问题就是,把查询条件放到 JOIN 子句和放到 WHERE 子句有什么不同呢?...: INNER JOIN:简单说如果使用的是 INNER JOIN,这两种查询的结果相同。...但是语义上:JOIN - 描述两个表之间的关系,WHERE - 从结果集中删除行。这两种方法直接存在显著的语义上的差别,尽管两种方法对结果和性能都无影响,但是选择正确的语法将有助于代码更易于被阅读。...OUTER JOIN:如果使用的是 OUTER JOIN,可能会不同,比如上面的 SQL 改成 LEFT JOIN,并且连接条件失败,则查询条件放到 JOIN 子句仍将获得一行,但是如果放到 WHERE...子句,则它将被过滤掉,因为 NULL 不等于 1。

    2.4K20

    SQL中关于Join、Inner JoinLeft Join、Right Join、Full Join、On、 Where区别

    前言:   今天主要的内容是要讲解SQL中关于Join、Inner JoinLeft Join、Right Join、Full Join、On、 Where区别和用法,不用我说其实前面的这些基本SQL...Join(where联立查询): 概念:用于两表或多表之间数据联立查询 select * from Students s,Class c where s.ClassId=c.ClassId ?...Inner Join(内连接查询): 概念:与Join相同,两表或多表之间联立查询数据,因此我们在使用多表join查询的时候既可以使用where关联,也可以是inner join关联查询 select...Left Join(左连接查询): 概念:以左表中的数据为主,即使与右表中的数据不匹配也会把左表中的所有数据返回 select * from Students s left join Class c...Right Join(右连接查询): 概念:与Left Join的用法相反,是以右表中的数据为主,即使左表中不存在匹配数据也会把右表中所有数据返回 select * from Students s right

    6.2K21

    LEFT JOIN的时候应该用ON还是WHERE

    说的是LEFT JOIN关联表中ON,WHERE后面跟条件的区别。 当时确实有点懵逼~经常做这种left join,inner join连接,却发现居然只是模糊的认识。...既然是面试题是left join,那咱就试试。 ? 从上述结果知道, left join会将左表的所有记录都显示出来,而在右表不匹配on条件的数据行则该列显示为Null。...而where条件由于在left join之外,所以是对连接之后的结果再次过滤。 那这是为什么呢?? 因为数据库在通过连接两张或多张表来返回记录时,都会生成一张中间的临时表,然后再将这张临时表返回。...既然left join是这个结果,那就刨根问底,inner join又是咋回事呢。 ?...inner join具有left和right的特性的并集,需要两个表中的数据都符合on条件,才能被筛选出来。 到这里,我们就明白了on和where之前的区别。

    5.1K40

    LEFT JOIN条件在on后面和在where后面的区别

    LEFT JOIN条件在ON后面和在WHERE后面的区别 Persion表 截屏2023-05-26 21.53.03.png City表 截屏2023-05-26 21.53.20.png 简单的...LEFT JOIN SELECT * FROM Person p LEFT JOIN City c ON p.City = c.City 执行结果 截屏2023-05-26 21.55.51.png...-26 21.57.25.png 我们把条件放到WHERE试试 SELECT * FROM Person p LEFT JOIN City c ON p.City = c.City WHERE c.City...2、where条件是在临时表生成好后,再对临时表进行过滤的条件。这时已经没有left join的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉。...结论 1、LEFT JOIN 今天ON条件过滤时候,只会对右表数据条件过滤,对左表数据没有任何影响 2、WHERE 条件是对结果表进行过滤,所以会对左表数据产生影响 3、INNER JOIN ON

    33120

    如何在 SQL 中使用 LEFT、RIGHT、INNER、OUTER、FULL 和 SELF JOIN

    这是通过使用诸如“LEFT JOIN”、“INNER JOIN”和“FULL OUTER JOIN”等术语来实现的。 每个类别都有自己的一组应用程序。 希望下面的比较表可以帮助您识别它们的小差异。...gt LEFT JOIN Country_Code cc ON gt.country_code = cc.fips_code; 查询结果: image.png INNER JOIN 当我们想查看两个表的交集时...gt FULL OUTER JOIN Country_Code cc ON gt.country_code = cc.fips_code; 查询结果: image.png RIGHT JOIN 右连接与左连接相同...,除了 RIGHT JOIN 子句返回表中的所有行,而 FROM 子句只返回表中匹配的行。...因为 RIGHT JOIN结果可以通过在 LEFT JOIN 中交换两个连接的表名来实现,所以很少使用 RIGHT JOIN

    2K40

    MYSQL IN EXISTS LEFT JOIN 结果不同的问题?

    = 2; 上面的三个SQL 看上去要表达一个目的,实际上从结果上看,1 2 SQL 的结果是一致的,第三个用 LEFT JOIN 表达的SQL 的结果和前两个不一样。...2 LEFT JOIN 是是存在一对多的关系 见下图这个就是,通过left JOIN 查询后的数据,明显与上个 EXIST ,IN 的结果中,多个 3个 2 原因是在于 实际上在film_actor...中就存在 4条 film_id =2 的记录,所以LEFT JOIN 如实的包括了4 个2 的记录, 而 EXIST IN 则带有去重的功能,所以在结果中只有一个 2 的记录。...如果要LEFT JOIN 中查询的结果与 EXIST IN 一致则可以在查询语句中加入group by 来去重。...group by fi.film_id) as t; 所以在撰写语句的时候,要明白 IN EXIST 和 LEFT JOIN 之间的区别,避免结果不是自己要的。

    1.8K50

    大数据 面试 SQL left join 测试结果

    这个题目的正确答案为B,下面是大家选择结果,准确率为36%,说明大家还是忽略了一些基础知识的细节的。 我们可以看到,选择集中在B和C,差别点在结果是否包含“1,null”该行。...第一点:大家都能够确定的是t2.id肯定是NULL,说明大家对于on条件中的t1.id = 2 的关联条件,可以限制t2表的结果; 第二点:left join 中的on条件是关联条件,不限定左表数据,所以...t1表中的所有数据都需要保留; 第三点:在真实需求下,期望得出C的结果是错写出该SQL,产出C结果的SQL如下: select t1.id, t2.id from t1 left join t2 on...t1.id=2 ) new_t1 left join ( select id from t2 )new_t2 on new_t1.id = new_t2.id 3.群里的朋友也给出使用CETs...new_t1.id, new_t2.id from new_t1 left join new_t2 on new_t1.id = new_t2.id

    18410

    数据库系列 | left join加上where条件咋了?

    1SQL语句:left join后面加上where条件 数据库在通过连接两张或多张表来返回记录时,都会生成一张中间的临时表,然后再将这张临时表返回给用户 2SQL LEFT JOIN 关键字 LEFT...3LEFT JOIN 关键字语法 SELECT column_name(s) FROM table_name1 LEFT JOIN table_name2 ON table_name1.column_name...=table_name2.column_name **注释:**在某些数据库中, LEFT JOIN 称为 LEFT OUTER JOIN。...where条件是在临时表生成好后,再对临时表进行过滤的条件 where 条件加上,已经没有left join的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉 过滤条件放在 where后面: 是先连接然生成临时查询结果...,然后再筛选 过滤条件放在 on后面: 先根据条件过滤筛选,再连,生成临时查询结果

    1K10

    SQL语句中 left join 后用 on 还是 where,区别大了!

    在使用left join时,on 和 where 条件的区别如下: on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录。...where条件是在临时表生成好后,再对临时表进行过滤的条件。这时已经没有left join的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉。...join tab2 on (tab1.size = tab2.size) where tab2.name=’AAA’ select * form tab1 left join tab2 on (tab1...其实以上结果的关键原因就是left join,right join,full join的特殊性,不管on上的条件是否为真都会返回left或right表中的记录,full则具有left和right的特性的并集...而inner jion没这个特殊性,则条件放在on中和where中,返回的结果集是相同的。

    1.2K10

    SQL语句中 left join 后用 on 还是 where,区别大了!

    后来发现 join on and 不会过滤结果记录条数,只会根据and后的条件是否显示 B表的记录,A表的记录一定会显示。...在使用left join时,on 和 where 条件的区别如下: on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录。...where条件是在临时表生成好后,再对临时表进行过滤的条件。这时已经没有left join的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉。...join tab2 on (tab1.size = tab2.size) where tab2.name=’AAA’ select * form tab1 left join tab2 on (tab1...而inner jion没这个特殊性,则条件放在on中和where中,返回的结果集是相同的。

    46520

    面试官:left join 后用 on 和 where 有什么区别?

    后来发现 join on and 不会过滤结果记录条数,只会根据 and 后的条件是否显示 B 表的记录,A 表的记录一定会显示。...在使用 left join 时,on 和 where 条件的区别如下: on 条件是在生成临时表时使用的条件,它不管 on 中的条件是否为真,都会返回左边表中的记录。...where 条件是在临时表生成好后,再对临时表进行过滤的条件。这时已经没有 left join 的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉。...on 条件: tab1.size = tab2.size and tab2.name=’AAA’ (条件不为真也会返回左表中的记录) 其实以上结果的关键原因就是 left join,right join...而 inner jion 没这个特殊性,则条件放在 on 中和 where 中,返回的结果集是相同的。

    57010
    领券