oracle中内连接和外连接的区别-Oracle
Oracle 中内连接和外连接的区别
定义:
- 内连接 (INNER JOIN):仅返回两个或更多表中所有匹配行的数据。
- 外连接:返回两个或更多表中所有匹配行的数据,以及来自仅存在于一个表中的行。
类型:
外连接有三种类型:
- 左外连接 (LEFT OUTER JOIN):返回左表中的所有行,以及与之匹配的右侧表中的行。
- 右外连接 (RIGHT OUTER JOIN):返回右表中的所有行,以及与之匹配的左侧表中的行。
- 全外连接 (FULL OUTER JOIN):返回来自两个表的行,即使行之间没有匹配。
区别:
特征 | 内连接 | 左外连接 | 右外连接 | 全外连接 |
---|---|---|---|---|
匹配原则 | 仅匹配行 | 左侧表匹配 | 右侧表匹配 | 两侧表匹配 |
返回行 | 匹配行 | 左侧表所有行 | 右侧表所有行 | 两侧表所有行 |
空值处理 | 仅显示匹配行 | 用 NULL 填充右侧表空值 | 用 NULL 填充左侧表空值 | 用 NULL 填充两侧表空值 |
举例:
假设我们有两个表:
- 表 A:id, name
- 表 B:id, address
内连接:
SELECT * FROM A INNER JOIN B ON A.id = B.id;
登录后复制
返回:仅具有匹配 id 的行。
左外连接:
SELECT * FROM A LEFT OUTER JOIN B ON A.id = B.id;
登录后复制
返回:所有来自表 A 的行,以及具有匹配 id 的来自表 B 的行(如果有)。非匹配的行用 NULL 填充。
示例查询:
以下查询使用左外连接将两个表中的数据连接起来,并显示所有客户及其地址:
SELECT customers.name, orders.order_date, products.product_name FROM customers LEFT OUTER JOIN orders ON customers.id = orders.customer_id LEFT OUTER JOIN products ON orders.product_id = products.id;
登录后复制
通过理解内连接和外连接之间的区别,开发人员可以有效地使用这些连接来提取来自不同表的数据,并满足特定的数据查询要求。