请留意,"Id_P" 列把上面的两个表联系了起来。
方式1:根据两个或多个表中的列之间的关系
我们可以通过引用两个表的方式,从两个表中获取数据:
谁订购了产品,并且他们订购了什么产品?
SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo
FROM Persons, Orders
WHERE Persons.Id_P = Orders.Id_P
结果集:
LastName | FirstName | OrderNo |
Adams |
John |
22456 |
Adams |
John |
24562 |
Carter |
Thomas |
77895 |
Carter |
Thomas |
44678 |
这个方式看起来很直观,也是我们经常比较常用的,但没办法解决上面的问题,但是我们可以使用下面的join方式解决。
方式2:join
不同的 SQL JOIN
除了我们在上面的例子中使用的 INNER JOIN(内连接),我们还可以使用其他几种连接。
下面列出了您可以使用的 JOIN 类型,以及它们之间的差异。
- JOIN: 如果表中有至少一个匹配,则返回行
- LEFT JOIN: 即使右表中没有匹配,也从左表返回所有的行
- RIGHT JOIN: 即使左表中没有匹配,也从右表返回所有的行
- FULL JOIN: 只要其中一个表中存在匹配,就返回行
1)、SQL INNER JOIN 关键字
在表中存在至少一个匹配时,INNER JOIN 关键字返回行。
INNER JOIN 关键字语法
SELECT column_name(s)
FROM table_name1
INNER JOIN table_name2
ON table_name1.column_name=table_name2.column_name
注释:INNER JOIN 与 JOIN 是相同的。
内连接(INNER JOIN)实例
现在,我们希望列出所有人的定购。
您可以使用下面的 SELECT 语句:
SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo
FROM Persons
INNER JOIN Orders
ON Persons.Id_P=Orders.Id_P
ORDER BY Persons.LastName
结果集:
LastName | FirstName | OrderNo |
Adams |
John |
22456 |
Adams |
John |
24562 |
Carter |
Thomas |
77895 |
Carter |
Thomas |
44678 |
INNER JOIN 关键字在表中存在至少一个匹配时返回行。如果 "Persons" 中的行在 "Orders" 中没有匹配,就不会列出这些行。
2)、SQL LEFT JOIN 关键字
LEFT JOIN 关键字会从左表 (table_name1) 那里返回所有的行,即使在右表 (table_name2) 中没有匹配的行。(可以解决上面的问题)
LEFT JOIN 关键字语法
SELECT column_name(s)
FROM table_name1
LEFT JOIN table_name2
ON table_name1.column_name=table_name2.column_name
注释:在某些数据库中, LEFT JOIN 称为 LEFT OUTER JOIN。
左连接(LEFT JOIN)实例
现在,我们希望列出所有的人,以及他们的定购 - 如果有的话。
您可以使用下面的 SELECT 语句:
SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo
FROM Persons
LEFT JOIN Orders
ON Persons.Id_P=Orders.Id_P
ORDER BY Persons.LastName
结果集:
。
致谢:感谢您的耐心阅读!
本类排行
今日推荐
-
辽宁移动动监正式版
版本:v1.3.4
大小:34.8M
日期:2024-05-18
-
可蚁点司机官方版
版本:v1.0.0
大小:36.3M
日期:2024-05-18
-
忻州市政府网正式版
版本:v2.00
大小:13.5M
日期:2024-05-18
-
今天医生安卓版
版本:v1.0.6
大小:10.5M
日期:2024-05-18
-
伽遇瑜伽官方版
版本:v1.0.30
大小:64.5M
日期:2024-05-18
-
恒星影视仓在线观看版
版本:v1.0.1
大小:27.41MB
日期:2024-05-18
热门手游
-
像素火影破解版
版本:v1.00.42
大小:222.66MB
日期:2024-05-18
-
谁先阵亡2完整版
版本:v1.0
大小:75.17MB
日期:2024-05-18
-
闪客连打明日英雄正式版
版本:v1.0
大小:65.31MB
日期:2024-05-18
-
七日重生正式版
版本:v2.6.2
大小:532.92MB
日期:2024-05-18
-
异形探索正式版
版本:v6.6.34
大小:160.63MB
日期:2024-05-18
-
3D超级保龄球大师官方版
版本:v1.1
大小:73.15MB
日期:2024-05-18
|
---|
|