left outer join on和inner join on区别
时间: 2023-07-07 17:14:52 浏览: 117
LEFT OUTER JOIN 和 INNER JOIN 都是用于在 MySQL 中连接两个或多个表格的方式,但是它们的区别在于连接的方式和结果集的不同。
LEFT OUTER JOIN(左外连接)是以左边的表格为基础,连接右边的表格,保留左边表格中所有记录和右边表格中符合条件的记录。如果右边的表格中没有符合条件的记录,则用 NULL 填充。例如:
```
SELECT *
FROM table1
LEFT OUTER JOIN table2
ON table1.column1 = table2.column1;
```
这个语句将会以 table1 表格为基础,连接 table2 表格,并保留 table1 表格中的所有记录和 table2 表格中符合条件的记录。如果 table2 表格中没有符合条件的记录,则使用 NULL 填充。
INNER JOIN(内连接)是以两个表格的交集为基础,连接两个表格,只返回符合条件的记录。例如:
```
SELECT *
FROM table1
INNER JOIN table2
ON table1.column1 = table2.column1;
```
这个语句将会以 table1 和 table2 表格的交集为基础,连接两个表格,并只返回符合条件的记录。
需要注意的是,在使用 LEFT OUTER JOIN 时,如果左边表格中有重复记录,则会保留重复记录,而 INNER JOIN 则不会保留重复记录。
相关问题
inner join 和 left outer join区别
### 回答1:
inner join(内连接)和left outer join(左外连接)都是SQL中用于合并两个或多个表的操作。它们之间的区别在于当连接条件不满足时如何处理。
inner join是根据连接条件将两个表中符合条件的行合并在一起,并返回满足条件的结果。这意味着只有当连接条件在两个表中都匹配时,才会返回结果。如果有一张表中的行没有匹配的行,则这些行将被排除在结果之外。
left outer join则会返回左表中的所有行,同时将右表中符合连接条件的行合并在一起。如果右表中的行没有与左表匹配的行,则会在结果中用NULL值填充这些行。左外连接保证了左表的所有行都会出现在结果中,而不管右表中是否有匹配的行。
举个例子说明,假设我们有两个表,一个是订单表,另一个是顾客表。订单表中的字段包括订单号和顾客ID,顾客表中的字段包括顾客ID和顾客姓名。如果我们使用inner join连接这两个表,只有在订单表中的顾客ID能够在顾客表中找到匹配的ID时,才会返回结果。而如果我们使用left outer join连接这两个表,则不论订单表中的顾客ID是否在顾客表中有匹配,都会返回订单表中的所有行,并在没有匹配的情况下用NULL值填充顾客姓名。
总结来说,inner join只返回满足连接条件的行,而left outer join保证左表的所有行都会出现在结果中,不管右表中是否有匹配的行。
### 回答2:
Inner join(内连接)和left outer join(左外连接)是SQL中两种常用的连接查询方式。
Inner join是通过匹配两个表中的行,返回满足条件的行的连接结果。它只返回两个表中行匹配的行,即只返回在两个表中都存在的行。若某行在一个表中存在,但在另一个表中不存在匹配的行,则该行不会出现在结果集中。这意味着使用Inner join可以过滤掉没有匹配的行,只返回双方都需要的数据。
Left outer join是在Inner join的基础上,还包含了左边表中的所有行。它返回所有左表中的行,无论在右表中是否存在匹配的行。如果某行在左表存在,而在右表中没有匹配的行,则返回的结果中对应的字段将会是空值(NULL)。换句话说,Left outer join保留了左表中的所有行,并将右表中匹配的行合并到结果集中。
总结一下,Inner join只返回两个表都存在的行,而Left outer join除了返回两个表都存在的行,还会返回左表中的所有行。在实际使用中,需要根据具体的需求来选择使用哪种连接方式。
inner join,left outer join,right outer join,full outer join
inner join是一种等值连接,它只返回两个表中联结字段相等的行。left outer join是左外连接,它返回包括左表中的所有记录和右表中联结字段相等的记录。right outer join是右外连接,它返回包括右表中的所有记录和左表中联结字段相等的记录。full outer join是全外连接,它返回包括左表和右表中的所有记录,无论是否有匹配的记录。所以,这些连接类型主要区别在于它们返回的记录集合的不同。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* [inner join、outer join、right join、left join 之间的区别](https://blog.csdn.net/dingjianmin/article/details/92009385)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"]
- *2* *3* [oracle基础积累-join,left join,right join,inner join,full join,left outer join,right outer join 之间...](https://blog.csdn.net/zhangbeizhen18/article/details/101002029)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]
阅读全文