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 

建议采用联合查询 join 而且使用全连接(FULL JOIN)方式

select *

from web_pian

FULL JOIN Orders

ON web_pian.mingcheng=web_shang.mingcheng

Order by web_pian.mingcheng

解释下:FULL Join 全连接将会输出所有的记录,即使有些空缺,和Left Join 左连接有所不同


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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存