登录 |  注册
首页 >  数据库 >  SQL >  SQL inner join内部连接

SQL inner join内部连接

JOIN连接的作用

JOIN 连接用于把来自两个或多个表的行结合起来,基于这些表之间的共同字段。

最常见的 JOIN 类型:INNER JOIN(简单的 JOIN)。 INNER JOIN 从多个表中返回满足 JOIN 条件的所有行。

示例数据库

让我们看看选自 "Orders" 表的数据:

m1.png

然后,看看选自 "Customers" 表的数据:

m2.jpg

请注意,"Orders" 表中的 "客户ID" 列指向 "Customers" 表中的客户ID。上面这两个表是通过 "客户ID" 列联系起来的。

JOIN实例

我们想知道每个订单ID都是哪些客户订购的,以及具体的订单时间。我们运行下面的 SQL 语句(包含 INNER JOIN):

SELECT o.订单ID, c.姓名, o.订单日期
FROM Orders o
INNER JOIN Customers c
ON o.客户ID=c.客户ID;

运行结果如下所示:

m3.png

不同的 JOIN

在我们继续讲解实例之前,我们先列出您可以使用的不同的 SQL JOIN 类型:

  • INNER JOIN:如果表中有至少一个匹配,则返回行

  • LEFT JOIN:即使右表中没有匹配,也从左表返回所有的行

  • RIGHT JOIN:即使左表中没有匹配,也从右表返回所有的行

  • FULL JOIN:只要其中一个表中存在匹配,则返回行

  • INNER JOIN内部链接

INNER JOIN

关键字选择两个表中具有匹配值的记录。

SQL INNER JOIN 语法

SELECT column_name(s)FROM table1
INNER JOIN table2 ON 
table1.column_name = table2.column_name;

m4.jpg

注释:INNER JOIN 与 JOIN 是相同的,上面的示例就是INNER JOIN

LEFT JOIN

SQL左链接LEFT JOIN关键字返回左表(表1)中的所有行,即使在右表(表2)中没有匹配。

如果在正确的表中没有匹配,结果是NULL。

SQL LEFT JOIN 语法

SELECT column_name(s)
FROM table1
LEFT JOIN table2
ON table1.column_name=table2.column_name;

或:

SELECT column_name(s)
FROM table1
LEFT OUTER JOIN table2
ON table1.column_name=table2.column_name;

注释:在一些数据库中,LEFT JOIN称为LEFT OUTER JOIN。

LEFT JOIN示例

我们想看看客户Customers表中的所有用户是否都有下单,可以使用如下查询语言:

SELECT c.姓名,o.订单ID,  o.订单日期
FROM Customers c
LEFT JOIN Orders o
ON o.客户ID=c.客户ID;

结果:

m5.png

我们发现刘二,李四,赵七没有对应的订单ID和订单日期,是因为他们没有在订单表Orders中存在,没有匹配上他们的信息。但是由于是左连接,就把主表Customers的信息全部显示出来了,就是对应上图的table1。

RIGHT JOIN

SQL右链接 RIGHT JOIN 关键字返回右表(table2)的所有行,即使在左表(table1)上没有匹配。如果左表没有匹配,则结果为NULL。

SQL RIGHT JOIN 语法

SELECT column_name(s) FROM table1
RIGHT JOIN table2 ON 
table1.column_name = table2.column_name;

注释:在一些数据库中,RIGHT JOIN 称为 RIGHT OUTER JOIN。

m6.jpg

右连接与左连接的主表刚好相反,会将table2中的数据完全显示,如果table1中没有匹配上的就不显示。 

FULL OUTER JOIN

当左(表1)或右(表2)表记录匹配时,FULL OUTER JOIN关键字将返回所有记录。

注意: FULL OUTER JOIN可能会返回非常大的结果集!

SQL FULL OUTER JOIN 语法

SELECT column_name(s) FROM table1
FULL OUTER JOIN table2 ON 
table1.column_name = table2.column_name;

m7.jpg

全连接就是将table1和table2的内容完全显示,不管有没有匹配上。

批注

JOIN在SQL中占有重要的地位,通过JOIN我们可以将有匹配关系的两张表或更多表进行关联,来获取我们想要的数据。关联的方式也比较灵活,常用的就是INNER JOIN,请务必掌握它。

上一篇: SQLJoin连接
下一篇: SQL左连接
推荐文章
  • mysql只支持一种join算法:Nested-LoopJoin(嵌套循环连接),但Nested-LoopJoin有三种变种:SimpleNested-LoopJoin,IndexNested-LoopJoin,BlockNested-LoopJoin(简单-索引-缓冲区)原理:1.SimpleNe
  • redis是一个内存数据库,一旦断电或服务器进程退出,内存数据库中的数据将全部丢失,所以需要redis持久化 redis持久化就是把数据保存在磁盘上,利用永久性存储介质将数据保存,在特定的时间将保存的数据进行恢复的工作机制redis提供两种持久化机制RDB:存储数据结果,关注点在数据AOF:存储操作
  • 通过SQL的执行过程来介绍MySQL的基础结构.     首先有一个user_info表,表里有一个id字段,执行下面这条查询语句:Select * form user_info where i
  • 索引(Index)是帮助MySQL高效获取数据的数据结构,索引的目的在于提高查询效率,就像字典和书籍的目录一样,有了目录,可以帮助你快速查找你需要的内容。可以理解为一个排好序的快速查找数据结构。也就是
  • 说到数据库事务,大家脑子里一定很容易蹦出一堆事务的相关知识,如事务的ACID特性,隔离级别,解决的问题(脏读,不可重复读,幻读)等等,但是可能很少有人真正的清楚事务的这些特性又是怎么实现的,为什么要有四个隔离级别。今天我们就先来聊聊MySQL中事务的隔离性的实现原理,后续还会继续出文章分析其他特性的
  • 前面我们系统了解了一个查询语句的执行流程,并介绍了执行过程中涉及的处理模块。相信你还记得,一条查询语句的执行过程一般是经过连接器、分析器、优化器、执行器等功能模块,最后到达存储引擎。那么,一条更新语句
学习大纲