简单易懂,MySQL里的各种JOIN

4周前 (11-13 03:25)阅读1回复0
路亚哦哦哦
路亚哦哦哦
  • 管理员
  • 注册排名7
  • 经验值89510
  • 级别管理员
  • 主题17902
  • 回复0
楼主

来 源:SQL数据库

01

JOIN毗连的感化

JOIN 毗连用于把来自两个或多个表的行连系起来,基于那些表之间的配合字段。

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

留意:毗连不是物理实体,它在数据库的物理表中是不存在的,只要当MySQL需要利用毗连来停止查询时才会利用到。

02

示例数据库

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

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

简单易懂,MySQL里的各类JOIN

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

03

JOIN实例

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

FROMOrders o

INNERJOINCustomers c

ONo.客户 ID=c.客户 ID;

运行成果如下所示:

简单易懂,MySQL里的各类JOIN

04

差别的 JOIN

在我们继续讲解实例之前,我们先列出您能够利用的差别的 SQL JOIN 类型:

INNER JOIN:若是表中有至少一个婚配,则返回行

LEFT JOIN:即便右表中没有婚配,也从左表返回所有的行

RIGHT JOIN:即便左表中没有婚配,也从右表返回所有的行

FULL JOIN:只要此中一个表中存在婚配,则返回行

05

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

06

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表中的所有用户能否都有下单,能够利用如下查询语言:

SELECTc.姓名,o.订单 ID, o.订单日期

FROMCustomers c

LEFTJOINOrders o

ONo.客户 ID=c.客户 ID;

成果:

简单易懂,MySQL里的各类JOIN

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

07

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中没有婚配上的就不显示。

08

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的内容完全显示,不管有没有婚配上。

09

WHERE毗连

除了上面的JOIN毗连,我们在上一个子查询中其实有讲解到利用WHERE也能够停止毗连。

例如:要查询每个客户的订单数量,我们能够如许写

SELECT

`姓名`,

`客户ID`,

SELECTCOUNT(*)

FROMorders o

WHEREo. `客户ID`=c. `客户ID`

) AS'数量'

FROMcustomers c

成果为:

简单易懂,MySQL里的各类JOIN

那里利用SELECT COUNT(*)对表中的行停止计数,而且通过供给一条WHERE子句的毗连来婚配某个特定的客户ID 。

最初

回复【50】即可领取

《MySQL典范50题》

简单易懂,MySQL里的各类JOIN

《MySQL典范50题》部门内容

0
回帖

简单易懂,MySQL里的各种JOIN 期待您的回复!

取消
载入表情清单……
载入颜色清单……
插入网络图片

取消确定

图片上传中
编辑器信息
提示信息