图解5种Join连接及实战案例!(inner/ left/ right/ full/ cross)

数据库
Join 连接在日常开发用得比较多,但大家都搞清楚了它们的使用区别吗??一文带你上车~~

Join 连接在日常开发用得比较多,但大家都搞清楚了它们的使用区别吗??一文带你上车~~

内连接 inner join

内连接是基于连接谓词将俩张表(如A和B)的列组合到一起产生新的结果表,在表中存在至少一个匹配时,INNER JOIN 关键字返回行。 

 

下面是一个简单的使用案例

 

以下是运行代码及结果 

左外连接 left join

左外连接Left join关键字会从左表那里返回所有的行,即使是在右表中没有匹配到的行  

下面是一个简单的案例 

下面是测试用例 

右外连接 right join

右外连接关键字Right join会从右表那里返回所有的行,即使是在左表中没有匹配到的行 

 

下面是一个简单的案例 

下面是运行及其结果 

全连接 full join

全连接的关键字Full join,只要其中某个表中存在匹配,Full join 就会返回行 

下面是一个简单的案例 

 

以下是运行及结果 

注意一点 mysql中是不支持Full join 的但是orcal等数据库是支持的。 

如果在mysql要使用Full join就会报以下错误 

解决办法:同时使用左连接和右连接 

以下是一个简单的例子

交叉连接 cross join

交叉连接一般使用的比较少,交叉连接又称笛卡尔连接或者叉乘连接,如果,A和B是俩个集合,他们的交叉连接就是A*B 

以下是一个简单的案例 

https://blog.csdn.net/u013412790/article/details/51626307 

责任编辑:庞桂玉 来源: Java技术栈
相关推荐

2010-05-21 17:30:28

2023-10-07 00:06:09

SQL数据库

2010-09-09 15:51:22

sqlinner join语法

2009-09-16 17:07:00

linq实现Left

2010-04-21 17:51:36

Oracle左连接

2011-07-05 10:34:31

2010-05-05 10:32:06

Oracle左连接le

2024-01-09 09:46:13

数据库MySQL

2010-05-18 14:14:03

MySQL关联left

2010-05-21 14:36:00

MySQL left

2024-01-04 10:00:13

数据库性能

2017-02-16 08:41:09

数据Vlookup匹配

2019-04-16 15:18:28

SQLJOIN数据库

2020-03-05 11:10:18

Left join数据库MySQL

2022-01-26 22:14:59

HiveSQLSQL脚本

2012-06-18 14:22:09

HTML5

2024-10-05 00:00:10

SQL语句指定连接条

2021-08-03 09:33:55

HTTP网络协议TCP

2021-08-03 10:10:16

HTTP连接管理

2018-04-03 15:20:07

数据库MySQLjoin连接
点赞
收藏

51CTO技术栈公众号