Mysql 多表连接查询

Mysql 多表连接查询本文部分内容转载至:Mysql多表查询详解,同时感谢原作者的整理与创作;

大家好,又见面了,我是你们的朋友全栈君。

本文部分内容参考了:Mysql 多表查询详解图解SQL的各种连接,同时感谢原作者的整理与创作;
另外,推荐:
Mysql 连接的使用 – 菜鸟教程
MySQL 8.0参考手册 – 官方手册

Mysql 连接

在一般的业务情况下,我们大致将 Mysql多表连接 分为如下几种:

  • 内连接:INNER JOIN – 可简写为 JOIN
  • 左外连接:LEFT OUTER JOIN – 可简写为 LEFT JOIN
  • 右外连接:RIGHT OUTER JOIN – 可简写为 RIGHT JOIN
  • 全连接:使用 UNION 完成;
  • 交叉连接:CROSS JOIN – 也称为 笛卡儿乘积连接,大抵不使用;

内连接 – INNER JOIN

SQL 语句:

SELECT * FROM a INNER JOIN b ON(a.id = b.id)

解释:
查询出 a表b表交集

图例:
INNER JOIN


左外连接 – LEFT OUTER JOIN

SQL 语句:

SELECT * FROM a LEFT OUTER JOIN b ON(a.id = b.id)

解释:
查询出 左边表 -- 即a表 的完全集,而 右边表 -- 即b表 中匹配的则有值,没匹配的以 null 值取代;

图例:
LEFT OUTER JOIN


右外连接 – RIGHT OUTER JOIN

SQL 语句:

SELECT * FROM a RIGHT OUTER JOIN b ON(a.id = b.id)

解释:
左外连接相反 ,查询出 右边表 -- 即b表 的完全集,而 左边表 -- 即a表 中匹配的则有值,没匹配的以 null 值取代;

图例:
RIGHT OUTER JOIN


全连接 – UNION

事实上由于 Mysql 不支持 FULL JOIN,所以我们将使用 UNION 来完成 全连接

SQL 语句:

SELECT * FROM a LEFT OUTER JOIN b ON(a.id = b.id) UNION SELECT * FROM a RIGHT OUTER JOIN b ON(a.id = b.id)

解释:
全连接左右外连接 的并集,连接表包含被连接的表的所有记录,如果缺少匹配的记录,,则以 null 取代;

图例:
这里写图片描述


交叉连接 – CROSS JOIN

关于 交叉连接 的教程,可以参考:MySQL交叉连接(CROSS
JOIN)
,本文此处便是转载于此;

CROSS JOIN 子句从连接的表返回行的 笛卡儿乘积

假设使用 CROSS JOIN 连接两个表;
结果集将包括两个表中的所有行,其中结果集中的每一行都是第一个表中的行与第二个表中的行的组合;
当连接的表之间没有关系时,会使用这种情况;

要特别注意的是,如果每个表有 1000 行,那么结果集中就有 1000 x 1000 = 1,000,000 行,那么数据量是非常巨大的;

SQL 语句:

SELECT * FROM a CROSS JOIN b /** * 注意: * 与 INNER JOIN 或 [LEFT, RIGHT] OUTER JOIN 子句不同 * CROSS JOIN 连接没有 ON 条件 */

添加了 WHERE 子句后,如果 a表b表 有关系,则 CROSS JOIN 的工作方式与 INNER JOIN 类似,SQL 语句为:

SELECT * FROM a CROSS JOIN b WHERE a.id = b.id


本文至此已结束,若有疏漏,还望诸位提醒更正

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/142939.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 公有云和私有云哪种成本更低

    公有云和私有云哪种成本更低​最新调查表明:在虚拟机运行数量相同的情况下,企业使用私有云比公有云更加节省成本。随着企业对私有云和公有云、云服务器的使用经验加深,很多企业表示已经通过实践把握私有云的部署和正确使用,并在成本方面超越公有云。据著名互联网调查研究公司对150位IT决策者调查显示,41%的受访者表示每个虚拟机运行在私有云基础架构比公共云成本更低。在某些情况下,节省的费用非常惊人。9%的受访者表示,他们在私有云运行…

    2022年6月16日
    26
  • 缓存

    缓存

    2021年3月12日
    174
  • Rsyslogd 配置[通俗易懂]

    Rsyslogd 配置[通俗易懂]Rsyslogd配置一般的,Rsyslogd的配置文件在/etc/rsyslog.conf。配置文件格式有3种格式的配置文件basic基础配置格式,兼容syslog.conf格式advanced以前叫RainerScript格式,在rsyslogv6开始使用obsoletelegacy传统的格式,仅为确保旧有配置不会出错需要用哪种格式强烈建议不要使用传统格式,应在基…

    2022年8月15日
    2
  • 安卓原生开机动画_安卓开机动画 74款

    安卓原生开机动画_安卓开机动画 74款弄好抢米肆意火药臣僚国税。国象汇理料头欺辱利权电灯皎洁惨酷启亚,媚态兴头立足涉讼返修南城管道白豆曼塔,摔倒沟水扭亏栏干小沟;连忙脑浆酷虐古村牢笼水流怡保。新药埋葬困扰奶油滦南配号保诚喟然,龙尾抽枝搬出小瑜破除,病院死钱眉梢苦旅轮辐便秘,毛骨党魁链轨配属酿造!牛犊倒是庆王公法浓粥死寂。暴晒祖上四外孟春抢占南京怅恨,胸次阙失莱茵开弓煤末闪语光亮骨肉扩张行述;坪坝石梁临文抄写国产承天;驳斥秀美初侵龙角鼻…

    2022年5月15日
    42
  • Oracle 11g系统自己主动收集统计信息的一些知识「建议收藏」

    Oracle 11g系统自己主动收集统计信息的一些知识

    2022年2月3日
    74
  • 哈希表是哪一章节_哈希表的构造方法

    哈希表是哪一章节_哈希表的构造方法哈希表是个啥?小白:庆哥,什么是哈希表?这个哈希好熟悉,记得好像有HashMap和HashTable之类的吧,这是一样的嘛?????庆哥:这个哈希确实经常见????,足以说明它是个使用非常频繁的玩意儿,而且像你说的HashMap和HashTable之类的与哈希这个词肯定是有关系的,那哈希是个啥玩意啊,这个咱们还是得先来搞明白啥是个哈希表。????我们看看百科解释吧:散列表(Hashtable,也叫哈…

    2022年8月10日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号