sql join 查询

本文详细介绍了SQL JOIN的四种主要类型:内连接(INNER JOIN)、左连接(LEFT JOIN)、右连接(RIGHT JOIN)和全连接(FULL JOIN)。通过实例演示了每种连接方式在查询结果中的区别,帮助理解在实际项目中的应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

不同的 SQL JOIN

除了例子中使用的 INNER JOIN(内连接),我们还可以使用其他几种连接。

下面列出了您可以使用的 JOIN 类型,以及它们之间的差异。

  • jion: 如果表中有至少一个匹配,则返回行

    注释: inner join与 join是相同的。(内连接)

    ​ inner jion 关键字在表中存在至少一个匹配时返回行。如果 “Persons” 中的行在 “Orders” 中没有匹配,就不会列出这些行。

    select Persons.LastName, Persons.FirstName, Orders.OrderNo
    FROM Persons
    inner join Orders
    ON Persons.Id_P=Orders.Id_P
    ORDER BY Persons.LastName
    

例如:
​ “Persons” 表
在这里插入图片描述
​ “Orders” 表:
在这里插入图片描述
​ 结果集:
在这里插入图片描述

  • left join: 即使右表中没有匹配,也从左表返回所有的行**(左连接)**

    ​ **注释:**left join 关键字会从左表 (Persons) 那里返回所有的行,即使在右表 (Orders) 中没有匹配的行。

SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo
FROM Persons
LEFT JOIN Orders
ON Persons.Id_P=Orders.Id_P
ORDER BY Persons.LastName

​ 结果集:
在这里插入图片描述

  • right join: 即使左表中没有匹配,也从右表返回所有的行**(右连接)**

    **注释:**RIGHT JOIN 关键字会从右表 (Orders) 那里返回所有的行,即使在左表 (Persons) 中没有匹配的行。

    SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo
    FROM Persons
    RIGHT JOIN Orders
    ON Persons.Id_P=Orders.Id_P
    ORDER BY Persons.LastName
    

结果集:
在这里插入图片描述

  • full join: 只要其中一个表中存在匹配,就返回行**(全连接)**

    **注解:**full join 关键字会从左表 (Persons) 和右表 (Orders) 那里返回所有的行。如果 “Persons” 中的行在表 “Orders” 中没有匹配,或者如果 “Orders” 中的行在表 “Persons” 中没有匹配,这些行同样会列出。

SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo
FROM Persons
FULL JOIN Orders
ON Persons.Id_P=Orders.Id_P
ORDER BY Persons.LastName

结果集:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值