MySQL基础知识——JOIN关联

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

最多见的 JOIN 类型:INNER JOIN(简单的 JOIN)。INNER JOIN 从多个表中返回知足 JOIN 条件的全部行。ide

注意:链接不是物理实体,它在数据库的物理表中是不存在的,只有当MySQL须要使用链接来进行查询时才会使用到。3d


示例数据库*code

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

MySQL基础知识——JOIN关联

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

MySQL基础知识——JOIN关联

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

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

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

运行结果以下所示:基础

MySQL基础知识——JOIN关联

不一样的 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;

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

MySQL基础知识——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。

MySQL基础知识——JOIN关联

LEFT JOIN示例

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

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

结果:

MySQL基础知识——JOIN关联

咱们发现刘二,李四,赵七没有对应的订单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。

MySQL基础知识——JOIN关联

右链接与左链接的主表恰好相反,会将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;

MySQL基础知识——JOIN关联

全链接就是将table1和table2的内容彻底显示,无论有没有匹配上。

WHERE链接

除了上面的JOIN链接,咱们在上一个子查询中其实有讲解到使用WHERE也能够进行链接。

例如:要查询每一个客户的订单数量,咱们能够这样写

SELECT 
`姓名`,
`客户ID`,
(
SELECT COUNT(*)
FROM orders o
WHERE o.`客户ID`=c.`客户ID` 
) AS '数量'
FROM customers c

结果为:

MySQL基础知识——JOIN关联

这里使用SELECT COUNT(*)对表中的行进行计数,而且经过提供一条WHERE子句的链接来匹配某个特定的客户ID 。

相关文章
相关标签/搜索