数据库左连接、右连接、内连接、全连接区别
基本定义:
left join (左连接):返回包括左表中的所有记录和右表中连接字段相等的记录。
right join (右连接):返回包括右表中的所有记录和左表中连接字段相等的记录。
inner join (等值连接或者叫内连接):只返回两个表中连接字段相等的行。
full join (全外连接):返回左右表中所有的记录和左右表中连接字段相等的记录。
1、内联接(典型的联接运算,使用像 = 或 <> 之类的比较运算符)。包括相等联接和自然联接。
内联接使用比较运算符根据每个表共有的列的值匹配两个表中的行。例如,检索 students和courses表中学生标识号相同的所有行。
2、外联接。外联接可以是左向外联接、右向外联接或完整外部联接。
在 FROM子句中指定外联接时,可以由下列几组关键字中的一组指定:
1)LEFT JOIN或LEFT OUTER JOIN
左向外联接的结果集包括 LEFT OUTER子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值。
2)RIGHT JOIN 或 RIGHT OUTER JOIN
右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。
3)FULL JOIN 或 FULL OUTER JOIN
完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。
3、交叉联接
交叉联接返回左表中的所有行,左表中的每一行与右表中的所有行组合。交叉联接也称作笛卡尔积。
FROM 子句中的表或视图可通过内联接或完整外部联接按任意顺序指定;但是,用左或右向外联接指定表或视图时,表或视图的顺序很重要。有关使用左或右向外联接排列表的更多信息,请参见使用外联接。
示例:
A表
id name
1 小王
2 小李
3 小刘
B表
id A_id job
1 2 老师
2 4 程序员
内连接:(只有2张表匹配的行才能显示)
select a.name,b.job from A a inner join B b on a.id=b.A_id
只能得到一条记录
小李 老师
左连接:(左边的表不加限制)
select a.name,b.job from A a left join B b on a.id=b.A_id
三条记录
小王 null
小李 老师
小刘 null
右连接:(右边的表不加限制)
select a.name,b.job from A a right join B b on a.id=b.A_id
两条记录
小李 老师
null 程序员
全外连接:(左右2张表都不加限制)
select a.name,b.job from A a full join B b on a.id=b.A_id
四条数据
小王 null
小李 老师
小刘 null
null 程序员
注:在sql中l外连接包括左连接(left join )和右连接(right join),全外连接(full join),等值连接(inner join)又叫内连接。
参考:https://blog.csdn.net/weixin_39220472/article/details/81193617
https://www.cnblogs.com/afirefly/archive/2010/10/08/1845906.html
相关文章
- relink 10g 数据库!
- 2.数据库约束
- DOCKER简明教程 : 通过容器连接REDIS数据库
- 常用jdbc连接数据库
- R语言-连接MySQL数据库方法
- 【Python连接数据库】Python连接Teradata数据库-JDBC方式
- cx_Oracle连接oracle数据库
- php数据库连接mysql与mysqli的区别与用法
- 数据库客户端快捷键(oracle+sybase)
- 数据库的最简单实现
- 如何创建最简单的 ABAP 数据库表,以及编码从数据库表中读取数据 (下)
- SAP 数据库表CRMD_ORDERADM_I字段OBJECT_TYPE的计算逻辑
- 使用JPA + Eclipselink操作PostgreSQL数据库
- paip.提升稳定性---c3p0数据库连接池不能取到连接An attempt by a client to checkout a Connection has timed out
- 构建数据库Web API无需编码:Instant Web API .Net Crack
- 成功解决:连接sql server时插入数据库内容为乱码,并且输出也为乱码
- ASP.NET Web Forms - 数据库连接
- 【JavaEE基础与高级 第42章】C3P0连接数据库操作顺序
- mysql数据库(10):数据 备份
- 1500万员工轻松管理,云原生数据库GaussDB让HR办公更高效
- 完整java开发中JDBC连接数据库代码和步骤
- 使用Jdbc的方式连接Clickhouse列式数据库
- java连接数据库的模糊查询
- mysql数据库连接的测试代码语句片断
- 数据库连接出错 expected key exchange group packet form server
- jdbc_连接数据库
- 从入门到精通:数据库辅助查询和连接查询
- Bytebase数据库 Schema 变更管理工具