来 源:SQL数据库
01
JOIN毗连的感化
JOIN 毗连用于把来自两个或多个表的行连系起来,基于那些表之间的配合字段。
最常见的 JOIN 类型:INNER JOIN(简单的 JOIN)。INNER JOIN 从多个表中返回满足 JOIN 前提的所有行。
留意:毗连不是物理实体,它在数据库的物理表中是不存在的,只要当MySQL需要利用毗连来停止查询时才会利用到。
02
示例数据库
让我们看看选自 "Orders" 表的数据:
然后,看看选自 "Customers" 表的数据:
请留意,"Orders" 表中的 "客户ID" 列指向 "Customers" 表中的"客户ID"。上面那两个表是通过 "客户ID" 列联络起来的。
03
JOIN实例
SELECTo.订单 ID, c.姓名, o.订单日期
FROMOrders o
INNERJOINCustomers c
ONo.客户 ID=c.客户 ID;
运行成果如下所示:
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。
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。
LEFT JOIN示例
我们想看看客户Customers表中的所有用户能否都有下单,能够利用如下查询语言:
SELECTc.姓名,o.订单 ID, o.订单日期
FROMCustomers c
LEFTJOINOrders o
ONo.客户 ID=c.客户 ID;
成果:
我们发现刘二,李四,赵七没有对应的订单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。
右毗连与左毗连的主表刚好相反,会将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;
全毗连就是将table1和table2的内容完全显示,不管有没有婚配上。
09
WHERE毗连
除了上面的JOIN毗连,我们在上一个子查询中其实有讲解到利用WHERE也能够停止毗连。
例如:要查询每个客户的订单数量,我们能够如许写
SELECT
`姓名`,
`客户ID`,
SELECTCOUNT(*)
FROMorders o
WHEREo. `客户ID`=c. `客户ID`
) AS'数量'
FROMcustomers c
成果为:
那里利用SELECT COUNT(*)对表中的行停止计数,而且通过供给一条WHERE子句的毗连来婚配某个特定的客户ID 。
最初
回复【50】即可领取
《MySQL典范50题》
《MySQL典范50题》部门内容