oracle--left join and 和left join where的区别

本文解释了LEFT JOIN与INNER JOIN的区别,特别关注LEFT JOIN ON、AND及WHERE条件的应用,并通过示例说明不同JOIN类型如何影响查询结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

开发程序时,经常会遇到left join,inner join的语句,Join是关系型数据库系统的重要操作之一,相对来说速度要快一些,所以大家一般都会优先选择join语句。

     但是在做程序时,对于join的一些用法却不一定很清晰。今天给大家讲的是left join and 和left join where。

     数据库在通过连接两张或多张表来返回记录时,都会生成一张中间的临时表,然后再将这张临时表返回给用户。

     在使用left jion on时,and和where条件的区别如下:

     1、 on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录,and只会过滤掉B表中的记录。B表中不符合条件的部分全部被设置为null。

     2、where条件是在临时表生成好后,再对临时表进行过滤的条件。这时已经没有left join的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉。



 

    示例:

建表语句:

      create table tmp_lxq_1
(
  id varchar2(10),
  name varchar2(20)
);
insert   into tmp_lxq_1
select '1','张三' from dual;
insert   into tmp_lxq_1
select '2','李四' from dual;
insert   into tmp_lxq_1
select '3','王五' from dual;
commit;

tmp_lxq_1表结果:

ID NAME
1 张三
2 李四
3 王五

drop table tmp_lxq_2;
create table tmp_lxq_2
(
  id varchar2(10),
  subject varchar2(30),
  score varchar2(30)
);

insert   into tmp_lxq_2
select '1','语文','80' from dual;
insert   into tmp_lxq_2
select '2','数学','90' from dual;
insert   into tmp_lxq_2
select '4','英语','60' from dual;
commit;

tmp_lxq_2结果:

ID SUBJECT SCORE
1 语文 80
2 数学 90
4 英语 60

然后运行下面几个语句:

1.inner join

inner jion 取A表和B表的交集,不管A表在左还是B表在左。

 

select a.id,a.name,b.id,b.subject,b.score from tmp_lxq_1 a
inner join tmp_lxq_2 b
on a.id=b.id;

结果:

ID NAME ID SUBJECT SCORE
1 张三 1 语文 80
2 李四 2 数学 90

 

2.left join 

left join是以A表的记录为基础的,A可以看成左表,B可以看成右表,left join是以左表为准的。换句话说,左表(A)的记录将会全部表示出来,而右表(B)只会显示符合搜索条件的记录(例子中为: A.ID = B.ID)。B表记录不足的地方均为NULL。

 

select a.id,a.name,b.id,b.subject,b.score from tmp_lxq_1 a
left join tmp_lxq_2 b
on a.id=b.id;

1 张三 1 语文 80
2 李四 2 数学 90
3 王五   


3.left join and

left join and也是以A表的记录为基础的,A可以看成左表,B可以看成右表,left join and是以左表为准的。换句话说,左表(A)的记录将会全部表示出来,而右表(B)只会显示符合搜索条件的记录(例子中为: A.ID = B.ID)。B表记录不足的地方均为NULL,加上and条件后,A表记录也将全部被表示出来,而B表只会将符合条件的记录显示出来,B表记录中不符合条件的地方均显示为null。

 

select a.id,a.name,b.id,b.subject,b.score from tmp_lxq_1 a
left join tmp_lxq_2 b
on a.id=b.id
and b.score>=80;

ID NAME ID SUBJECT SCORE
1 张三 1 语文 80
2 李四 2 数学 90
3 王五   


4.left join where 

left join where条件是在临时表生成好后,再对临时表进行过滤的条件。这时已经没有left join的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉。

 

select a.id,a.name,b.id,b.subject,b.score from tmp_lxq_1 a
left join tmp_lxq_2 b
on a.id=b.id
where b.score>=80;

ID NAME ID SUBJECT SCORE
1 张三 1 语文 80
2 李四 2 数学 90

### 三、LEFT JOINWHERE 条件的使用方法 在 Oracle 数据库中,LEFT JOIN 用于返回左表中的所有记录,即使右表中没有匹配的行,也会保留左表的数据,并将右表的字段填充为 NULL。当 LEFT JOINWHERE 条件结合使用时,需要注意 WHERE 子句的作用时机,它是在 JOIN 操作完成之后对结果集进行过滤的,这可能会改变 LEFT JOIN 的原始语义[^1]。 #### 1. LEFT JOIN ON 条件的使用 LEFT JOIN 的 ON 子句用于定义连接条件,它在生成中间结果表时起作用。ON 条件不仅用于匹配左右表的数据,还可以包含额外的过滤条件,这些条件会影响中间表的生成过程。例如: ```sql SELECT tab1.id, tab1.size, tab2.name FROM tab1 LEFT JOIN tab2 ON tab1.size = tab2.size AND tab2.name = 'AAA'; ``` 该查询会在生成中间表时,同时判断 `tab1.size = tab2.size` `tab2.name = 'AAA'`,即使右表中没有满足条件的记录,左表的记录仍然会被保留[^3]。 #### 2. LEFT JOIN 后使用 WHERE 条件LEFT JOIN 之后使用 WHERE 条件时,该条件是对 JOIN 生成的中间表进行过滤,而不是在连接过程中起作用。这种情况下,LEFT JOIN 的语义可能会被破坏,因为 WHERE 条件会排除掉那些右表中没有匹配的行,从而导致 LEFT JOIN 的效果被削弱甚至失效。例如: ```sql SELECT tab1.id, tab1.size, tab2.name FROM tab1 LEFT JOIN tab2 ON tab1.size = tab2.size WHERE tab2.name = 'AAA'; ``` 此查询首先根据 `tab1.size = tab2.size` 生成中间表,然后再通过 `tab2.name = 'AAA'` 进行过滤。最终结果中只保留了右表中满足条件的记录,左表中未匹配的记录将被排除,这实际上等价于 INNER JOIN 的效果。 #### 3. 结合 ON WHERE 的最佳实践 为了确保 LEFT JOIN 的语义完整,建议将所有与连接相关的过滤条件放在 ON 子句中,而将与最终结果集过滤相关的条件放在 WHERE 子句中。例如: ```sql SELECT tab1.id, tab1.size, tab2.name FROM tab1 LEFT JOIN tab2 ON tab1.size = tab2.size AND tab2.name = 'AAA' WHERE tab1.id > 1; ``` 在此查询中,`tab2.name = 'AAA'` 被包含在 ON 子句中,确保 LEFT JOIN 的语义不受影响,而 `tab1.id > 1` 是对左表的进一步过滤,不影响 JOIN 的行为[^3]。 #### 4. LEFT JOINWHERE 条件的性能影响 在实际应用中,LEFT JOIN 后使用 WHERE 条件可能会导致性能下降,因为数据库需要先生成完整的中间表,然后再进行过滤。相比之下,将过滤条件放在 ON 子句中可以减少中间表的大小,从而提高查询效率。此外,在涉及视图的情况下,LEFT JOIN 的 ON 条件可能无法有效利用索引,导致查询性能不佳。此时可以考虑将 LEFT JOIN 替换为传统的 `(+)` 语法,以优化执行计划[^2]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值