当前位置: 代码网 > it编程>数据库>Mysql > Mysql关联查询的几种实现方式

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

2024年05月27日 Mysql 我要评论
在关系型数据库中,要进行多表查询,一般都会使用join连接。join连接的本质其实类似与集合的交并操作,mysql实现关联查询常见的几种方式如下;本次测试表结构和数据:a表b表1、左连接概念说明:左连

在关系型数据库中,要进行多表查询,一般都会使用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 行;

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

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

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com