LEFT OUTER JOIN 和left join 的区别
时间: 2024-01-04 14:20:14 浏览: 91
LEFT OUTER JOIN 和 LEFT JOIN 是相同的,它们都表示左外连接。左外连接是一种连接操作,它返回左边表的所有行,以及右边表中与左边表匹配的行。如果右边表中没有与左边表匹配的行,则返回 NULL 值。
左外连接和内连接的区别在于,内连接只返回两个表中匹配的行,而左外连接返回左边表的所有行,不管右边表中是否存在与之匹配的行。
以下是一个示例,演示了 LEFT OUTER JOIN 的用法:
```sql
SELECT *
FROM t_institution i
LEFT OUTER JOIN t_teller t ON i.inst_no = t.inst_no;
```
上述查询将返回 t_institution 表的所有行,以及与之匹配的 t_teller 表的行。如果 t_teller 表中没有与 t_institution 表匹配的行,则返回 NULL 值。
相关问题
left outer join和left join 区别
left join和left outer join是相同的,它们都表示左连接。在SQL查询中,左连接是连接两个或多个表的一种方法,其中左侧表的所有行都包括在结果中,而右侧表的匹配行只有在右侧表中存在匹配时才包含在结果中。因此,left join或left outer join返回左侧表的所有行,而右侧表的非匹配行为NULL。因此,left join和left outer join是相同的。
left outer join 和left join 区别
左外连接(left outer join)和左连接(left join)是数据库中两种常见的连接操作。
左连接(left join)是指从左表中选取所有记录,以及与右表中匹配的记录。如果右表中没有匹配的记录,则用 NULL 值填充。左连接是指左表中的记录会全部保留,而右表中没有匹配的记录会被过滤掉。
左外连接(left outer join)与左连接的概念类似,可以理解为左连接的扩展。左外连接是指从左表中选取所有记录,以及与右表中匹配的记录。如果右表中没有匹配的记录,则同样用 NULL 值填充。左外连接和左连接的区别在于,左外连接会保留右表中没有匹配的记录。
简而言之,左连接只保留左表中与右表有匹配的记录,而左外连接则保留左表中所有记录,不管是否与右表有匹配。
举个例子来说明:
假设有两个表 A 和 B:
表 A:
id name
1 Tom
2 Alice
3 John
表 B:
id age
1 25
3 30
使用左连接(left join)操作,结果如下:
id name age
1 Tom 25
2 Alice NULL
3 John 30
使用左外连接(left outer join)操作,结果如下:
id name age
1 Tom 25
2 Alice NULL
3 John 30
可以看到,左连接只保留了左表中与右表有匹配的记录(Tom 和 John),而左外连接保留了左表中所有记录(Tom、Alice 和 John)。
希望能够解答您的问题!如果还有其他问题,请随时提问。
阅读全文