Mysql关联查询的几种实现方式

 更新时间:2024年04月18日 09:30:06   作者:想养一只!  
这篇文章主要介绍了Mysql关联查询的几种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

在关系型数据库中,要进行多表查询,一般都会使用join连接。

join连接的本质其实类似与集合的交并操作,Mysql实现关联查询常见的几种方式如下;

本次测试表结构和数据:

  • A表

  • B表

1、左连接

概念说明:

左连接将左表A作为主表,右表B作为从表,左表作为外层循环,在右表中进行匹配,如果左表的记录在右表中没有匹配,则将该左表记录的右表项补空值;

 语法&测试:

语法关键字为 LEFT JOIN,影响行数 4 行;

2、右连接

概念说明:

右连接将右表B作为主表,左表A作为从表,右表作为外层循环,在左表中进行匹配,如果右表的记录在左表中没有匹配,则将该右表记录的左表项补空值;

语法&测试:

语法关键字为 RIGHT JOIN,影响行数 4 行;

3、内连接

概念说明:

内连接将左表A和右表B对于条件相匹配的项进行组合,在结果中只会出现同时在左表和右表出现的项;

语法&测试:

语法关键字为 INNER JOIN 或 JOIN(JOIN等价于INNER JOIN),影响行数 3 行;

4、全连接

概念说明:

全外连接将左表A和右表B的所有记录进行匹配,如果在另外表项中不存在记录,则补空值;

语法&测试:

语法关键字为 UNION 用来组合左连接和右连接,影响行数 5 行;

5、左外连接

概念说明:

左外连接选择将左表A作为主表,右表B作为从表,循环遍历右表,查找与条件满足的项,如果在右表中没有匹配的项,则补空值,并且在结果集中选择只在左表中存在的数据;

语法&测试:

左表A独有的数据,影响行数 1 行;

6、右外连接

概念说明:

右外连接选择将右表作为主表,左表作为从表,循环遍历左表,查找与join条件满足的项,如果在左表中没有匹配的项,则补空值,并且在结果集中选择只在右表中存在的数据;

语法&测试:

右表B独有的数据,影响行数 1 行;

7、全外连接

概念说明:

全外连接将全连接中左右表相交的部分排除;

语法&测试:

左表A和右表B独有的数据,影响行数 2 行;

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MySQL 5.6 (Win7 64位)下载、安装与配置图文教程

    MySQL 5.6 (Win7 64位)下载、安装与配置图文教程

    这篇文章主要介绍了MySQL 5.6 (Win7 64位)下载、安装与配置图文教程的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-07-07
  • Mysql数据库百万级数据测试索引效果

    Mysql数据库百万级数据测试索引效果

    这篇文章主要为大家介绍了Mysql数据库百万数据测试索引效果,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • MySQL优化及索引解析

    MySQL优化及索引解析

    这篇文章主要介绍了MySQL优化及索引解析,索引关系型数据库为了加速对表中行数据检索的数据结构,下面文章详细内容,需要的小伙伴可以参考一下
    2022-03-03
  • 用HAProxy来检测MySQL复制的延迟的教程

    用HAProxy来检测MySQL复制的延迟的教程

    这篇文章主要介绍了用HAProxy来检测MySQL复制的延迟的教程,HAProxy需要使用到PHP脚本,需要的朋友可以参考下
    2015-04-04
  • MySQL中SQL命令语句条件查询实例详解

    MySQL中SQL命令语句条件查询实例详解

    SELECT语句可以通过WHERE条件来设定查询条件,查询结果是满足查询条件的记录,下面这篇文章主要给大家介绍了关于MySQL中SQL命令语句条件查询的相关资料,需要的朋友可以参考下
    2022-11-11
  • mysql中insert并发问题(on DUPLICATE KEY UPDATE)

    mysql中insert并发问题(on DUPLICATE KEY UPDATE)

    本文主要介绍了mysql中insert并发问题(on DUPLICATE KEY UPDATE),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • mysql创建用户并赋予用户权限详细操作教程

    mysql创建用户并赋予用户权限详细操作教程

    这篇文章主要给大家介绍了关于mysql创建用户并赋予用户权限详细操作的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • 在MySQL中生成随机密码的方法

    在MySQL中生成随机密码的方法

    这篇文章主要介绍了在MySQL中生成随机密码的方法,作者还给出了密码所对应类型限制的参数表,需要的朋友可以参考下
    2015-05-05
  • MySql查询中按多个字段排序的方法

    MySql查询中按多个字段排序的方法

    在SQL查询中,经常需要按多个字段对结果进行排序,本文主要介绍了MySql查询中按多个字段排序的方法,具有一定的参考价值,感兴趣的可以了解一下
    2024-03-03
  • MySQL触发器运用于迁移和同步数据的实例教程

    MySQL触发器运用于迁移和同步数据的实例教程

    这篇文章主要介绍了MySQL触发器运用于迁移和同步数据的实例教程,分别是SQL Server数据迁移至MySQL以及同步备份数据表记录的两个例子,需要的朋友可以参考下
    2015-12-12

最新评论