gpt4 book ai didi

SQL语句中不同的连接JOIN及join的用法

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 25 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章SQL语句中不同的连接JOIN及join的用法由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

为了从两个表中获取数据,我们有时会用JOIN将两个表连接起来。通常有以下几种连接方式:

JOIN  or  INNER JOIN(内连接) : 这两个是相同的,要求两边表同时有对应的数据,返回行,任何一边缺失数据就不显示.

LEFT JOIN(左外连接):即使右边的表中没有匹配,也从左表返回所有的行.

RIGHT JOIN(右外连接):即使左边的表中没有匹配,也从右表返回所有的行.

FULL JOIN(全外连接):只要其中一个表中存在匹配就返回行.

如例,有grade表(课程号sn,分数scroe,学号id),student表(学号id,学生姓名name),要查询学生的姓名和成绩 。

  。

当JOIN或是INNER JOIN时, 。

?
1
SELECT s. name ,g.sn,g.score from student as s join grade as g on s.id = g.id

或者 。

?
1
SELECT s. name ,g.sn,g.score from student as s inner join grade as g on s.id = g.id

结果集如下 。

SQL语句中不同的连接JOIN及join的用法

当LEFT JOIN时, 。

?
1
SELECT s. name ,g.sn,g.score from student as s left join grade as g on s.id = g.id

结果集如下 。

SQL语句中不同的连接JOIN及join的用法

当RIGHT JOIN时, 。

?
1
SELECT s. name ,g.sn,g.score from student as s right join grade as g on s.id = g.id

结果集如下 。

SQL语句中不同的连接JOIN及join的用法

当FULL JOIN时, 。

?
1
SELECT s. name ,g.sn,g.score from student as s full join grade as g on s.id = g.id

结果集如下 。

SQL语句中不同的连接JOIN及join的用法

注意,两个表连接时用on,在使用left join(right join或full join)时,on与where的区别是:

on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录 。

where条件是在临时表生成好后再对临时表进行过滤的条件,这时已经没有left join的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉。如下图, 。

on条件为黄色部分 。

?
1
SELECT s. name ,g.sn,g.score from student as s left join grade as g on s.id = g.id and score =90

SQL语句中不同的连接JOIN及join的用法

?
1
SELECT s. name ,g.sn,g.score from student as s left join grade as g on s.id = g.id where score =90

SQL语句中不同的连接JOIN及join的用法

下面看下SQL中join的各种用法 。

1.自然连接(natural join) 。

自然连接将表中具有相同名称的列自动进行匹配,自然连接不必指定任何同等连接条件也不能认为指定哪些列需要被匹配,自然连接得到的结果表中,两表中名称相同的列只出现一次.

?
1
select * from employee natural join department;

2.内连接(inner join):产生的结果是A和B的交集(相同列里面的相同值) 。

内连接查询能将左表和右表中能关联起来的数据连接后返回,返回的结果就是两个表中所有相匹配的数据.

?
1
2
select * from TableA as A inner join TableB B on A.PK = B.PK;
select * from TableA as A inner join TableB B on A.PK > B.PK;


SQL语句中不同的连接JOIN及join的用法

3.外连接(outer join) 。

内连接是要显示两张表的内存,而外连接不要求如此,外连接可以依据连接表保留左表,右表或全部表的行为而分为左外连接右外连接和全连接.

?
1
select * from TableA as A left ( right / full ) join TableB as B on A.PA = B.PK;

Full Join:产生的结果是A和B的并集(如果没有相同的值会用null作为值) 。

SQL语句中不同的连接JOIN及join的用法

Left Join:产生表A的完全集,而B表中匹配的则有值(没有匹配的则以null值取代) 。


SQL语句中不同的连接JOIN及join的用法

Right Join:产生表B的完全集,而A表中匹配的则有值(没有匹配的则以null值取代) 。

SQL语句中不同的连接JOIN及join的用法

4.交叉连接(cross join) 。

又称笛卡尔连接,交叉连接返回两个集合的笛卡尔积.

?
1
select * from TableA cross join TableB;

参考链接:http://mazhuang.org/2017/09/11/joins-in-sql/ 。

总结 。

以上所述是小编给大家介绍的SQL语句中不同的连接join及join的用法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我网站的支持! 。

原文链接:https://www.cnblogs.com/goodboyaistudy/archive/2018/10/25/9844486.html 。

最后此篇关于SQL语句中不同的连接JOIN及join的用法的文章就讲到这里了,如果你想了解更多关于SQL语句中不同的连接JOIN及join的用法的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com