mysql连接方式

mysql连接方式,第1张

左连接:返回包括左表中的所有记录和右表中联结字段相等的记录

右连接:返回包括右表中的所有记录和左表中联结字段相等的记录

全连接:返回两个连接表的所有记录;mysql没有全连接

内连接:返回两个连接表连接字段相同的记录;

union:对两个结果集进行并集,并去重,当交换两个select语句顺序后,最终结果与不交换时无区别;

union all:对两个结果集进行并集,不去重,当交换两个select语句顺序后,最终结果与不交换时有区别;

举个例子 有一个学生表 班级 姓名 一个成绩表 姓名 成绩 我们需要返回X班的所有学生的成绩,但是班上有人缺考,也就是成绩表里没有姓名,我们先用on得到的就是有考试成绩的名字,通过外连接,我们就可以得到全班人的名字以及成绩。

SQL中的 join 可以根据相应条件把指定的表给结合起来并将数据返回。

内连接是基于连接谓词将俩张表(如A和B)的列组合到一起产生新的结果表,在表中存在至少一个匹配时,INNER JOIN 关键字返回行

左外连接Left join关键字会从左表那里返回所有的行,即使是在右表中没有匹配到的行 

右外连接关键字Right join会从右表那里返回所有的行,即使是在左表中没有匹配到的行 

全连接的关键字Full join,只要其中某个表中存在匹配,Full join 就会返回行

交叉连接一般使用的比较少,交叉连接又称笛卡尔连接或者叉乘连接,如果,A和B是俩个集合,他们的交叉连接就是A*B 

部门表数据

内连接inner join表示A表和B表的共有部分数据。

左连接 left join 表示A表和B表的公共部分,再加上A表的独有部分。

右连接right join 表示A表和B表公共部分,在加上B表的独有部分。

查找A表独有部分,则需查找A表和B表的共有部分并加上A表的独有部分,在将A表和B表的共有部分剔除即可(也就是挑选B的主键为空的数据)。

查找B表独有部分,则需查找A表和B表的共有部分并加上B表的独有部分,在将A表和B表的共有部分剔除即可(也就是挑选A的主键为空的数据)。

全连接则表示将A表和B表的公共部分及A表、B表的独有部分,所有数据都查询出来

指导图的全连接 full outer join 在mysql 语法报错!但是可以通过union关键字进行查询。

UNION会把 重复的行去掉,返回的行都是唯一的。如果想保留重复行,可以使用 UNION ALL 关键字。

UNION其实就是将A表和B表的共有部分及A表的独有部分(即左连接left join)加上A、B表共有部分及B表的独有部分(即右连接right join)合并起来,并进行去重即可。

查询A表独有部分并加上B表独有部分

实际就是查询A表的独有部分和B表的独有部分,使用UNION进行连接即可。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/6187857.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-17
下一篇 2023-03-17

发表评论

登录后才能评论

评论列表(0条)

保存