mysql中join的作用,MySQL基础知识——JOIN关联

JOIN连接的作用

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

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

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

示例数据库*

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

6773b50638f3e3af8f57166ae1d59ec9.png

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

f67a51588b3c7b8e2b1e7655d99194c1.png

请注意,"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;

运行结果如下所示:

7f3df05a0269eeb97045e93645a3393a.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;

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

4f5fd9506869cfefb34b81f82612af14.png

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。

766b37aab080048c0b570fcef029b876.png

LEFT JOIN示例

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

SELECT c.姓名,o.订单ID, o.订单日期

FROM Customers c

LEFT JOIN Orders o

ON o.客户ID=c.客户ID;

结果:

35cbd6df23255531bed4c283f1ab781c.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。

db93e8494b39ebc91189a88da5d2e20d.png

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

d5bbffc21afe82da5350fda8c21b1b9c.png

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

WHERE连接

除了上面的JOIN连接,我们在上一个子查询中其实有讲解到使用WHERE也可以进行连接。

例如:要查询每个客户的订单数量,我们可以这样写

SELECT

`姓名`,

`客户ID`,

(

SELECT COUNT(*)

FROM orders o

WHERE o.`客户ID`=c.`客户ID`

) AS '数量'

FROM customers c

结果为:

986b1e424291667f3d7c7ebc1d2e216d.png

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

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值