转自:https://blog.csdn.net/qq_35975416/article/details/78842958

sql查询中有一个非常重要的环节就是表的关联查询,一般使用left join,right join,inner join,他们之间的区别是什么呢?

下面我们通过具体的sql语句来演示,演示用的表名为test1/test2:

mysql> select * from test1;
+----+--------+------+------+
| id | name   | age  | sex  |
+----+--------+------+------+
|  0 | 小董   | 20   | 男   |
|  1 | 小王   | 15   | 男   |
|  2 | 小李   | 18   | 男   |
|  3 | 小红   | 16   | 女   |
+----+--------+------+------+
4 rows in set (0.00 sec)

mysql> select * from test2;
+----+--------+-----------------------+-------+
| id | name   | interest              | score |
+----+--------+-----------------------+-------+
|  1 | 小王   | 打篮球                | 81    |
|  2 | 小李   | 踢足球                | 84    |
|  3 | 小红   | 看动漫                | 99    |
|  4 | 小军   | 打游戏,打篮球        | 100   |
+----+--------+-----------------------+-------+
4 rows in set (0.00 sec)

mysql> select * from test1 t1 left join test2 t2 on t1.id=t2.id and t1.name=t2.name;
+----+--------+------+------+------+--------+-----------+-------+
| id | name   | age  | sex  | id   | name   | interest  | score |
+----+--------+------+------+------+--------+-----------+-------+
|  1 | 小王   | 15   | 男   |    1 | 小王   | 打篮球    | 81    |
|  2 | 小李   | 18   | 男   |    2 | 小李   | 踢足球    | 84    |
|  3 | 小红   | 16   | 女   |    3 | 小红   | 看动漫    | 99    |
|  0 | 小董   | 20   | 男   | NULL | NULL   | NULL      | NULL  |
+----+--------+------+------+------+--------+-----------+-------+
4 rows in set (0.12 sec)

mysql> select * from test2 t1 left join test1 t2 on t1.id=t2.id and t1.name=t2.name;
+----+--------+-----------------------+-------+------+--------+------+------+
| id | name   | interest              | score | id   | name   | age  | sex  |
+----+--------+-----------------------+-------+------+--------+------+------+
|  1 | 小王   | 打篮球                | 81    |    1 | 小王   | 15   | 男   |
|  2 | 小李   | 踢足球                | 84    |    2 | 小李   | 18   | 男   |
|  3 | 小红   | 看动漫                | 99    |    3 | 小红   | 16   | 女   |
|  4 | 小军   | 打游戏,打篮球        | 100   | NULL | NULL   | NULL | NULL |
+----+--------+-----------------------+-------+------+--------+------+------+
4 rows in set (0.00 sec)

mysql> select t1.id,t1.name,t1.interest,t1.score,t2.age,t2.sex from test2 t1 left join test1 t2 on t1.id=t2.id and t1.name=t2.name;
+----+--------+-----------------------+-------+------+------+
| id | name   | interest              | score | age  | sex  |
+----+--------+-----------------------+-------+------+------+
|  1 | 小王   | 打篮球                | 81    | 15   | 男   |
|  2 | 小李   | 踢足球                | 84    | 18   | 男   |
|  3 | 小红   | 看动漫                | 99    | 16   | 女   |
|  4 | 小军   | 打游戏,打篮球        | 100   | NULL | NULL |
+----+--------+-----------------------+-------+------+------+
4 rows in set (0.02 sec)

mysql> select t1.id,t1.name,t1.interest,t1.score,t2.age,t2.sex from test2 t1 inner join test1 t2 on t1.id=t2.id and t1.name=t2.name;
+----+--------+-----------+-------+------+------+
| id | name   | interest  | score | age  | sex  |
+----+--------+-----------+-------+------+------+
|  1 | 小王   | 打篮球    | 81    | 15   | 男   |
|  2 | 小李   | 踢足球    | 84    | 18   | 男   |
|  3 | 小红   | 看动漫    | 99    | 16   | 女   |
+----+--------+-----------+-------+------+------+
3 rows in set (0.00 sec)

mysql> select * from test1 t1 left join test2 t2 on t1.id=t2.id and t1.name=t2.name;
+----+--------+------+------+------+--------+-----------+-------+
| id | name   | age  | sex  | id   | name   | interest  | score |
+----+--------+------+------+------+--------+-----------+-------+
|  1 | 小王   | 15   | 男   |    1 | 小王   | 打篮球    | 81    |
|  2 | 小李   | 18   | 男   |    2 | 小李   | 踢足球    | 84    |
|  3 | 小红   | 16   | 女   |    3 | 小红   | 看动漫    | 99    |
|  0 | 小董   | 20   | 男   | NULL | NULL   | NULL      | NULL  |
+----+--------+------+------+------+--------+-----------+-------+
4 rows in set (0.00 sec)

mysql> select * from test1 t1 right join test2 t2 on t1.id=t2.id and t1.name=t2.name;
+------+--------+------+------+----+--------+-----------------------+-------+
| id   | name   | age  | sex  | id | name   | interest              | score |
+------+--------+------+------+----+--------+-----------------------+-------+
|    1 | 小王   | 15   | 男   |  1 | 小王   | 打篮球                | 81    |
|    2 | 小李   | 18   | 男   |  2 | 小李   | 踢足球                | 84    |
|    3 | 小红   | 16   | 女   |  3 | 小红   | 看动漫                | 99    |
| NULL | NULL   | NULL | NULL |  4 | 小军   | 打游戏,打篮球        | 100   |
+------+--------+------+------+----+--------+-----------------------+-------+
4 rows in set (0.00 sec)

mysql> select * from test1 t1 inner join test2 t2 on t1.id=t2.id and t1.name=t2.name;
+----+--------+------+------+----+--------+-----------+-------+
| id | name   | age  | sex  | id | name   | interest  | score |
+----+--------+------+------+----+--------+-----------+-------+
|  1 | 小王   | 15   | 男   |  1 | 小王   | 打篮球    | 81    |
|  2 | 小李   | 18   | 男   |  2 | 小李   | 踢足球    | 84    |
|  3 | 小红   | 16   | 女   |  3 | 小红   | 看动漫    | 99    |
+----+--------+------+------+----+--------+-----------+-------+
3 rows in set (0.00 sec)

从上面的截图可以很容易看出来三者之间的区别,left join 查出来的数据条数是以查询的表为主,right join查出来的数据条数是以关联表为主,inner join查出来的数据是在查询条件在两者的交集


(转) mysql中left join,right join,inner join的区别的更多相关文章

  1. MySQL 中 key, primary key ,unique key,index的区别

    一.key与primary key区别 CREATE TABLE wh_logrecord ( logrecord_id int(11) NOT NULL auto_increment, user_n ...

  2. 【转】Mysql中的排序规则utf8_unicode_ci、utf8_general_ci的区别总结

    Mysql中utf8_general_ci与utf8_unicode_ci有什么区别呢?在编程语言中,通常用unicode对中文字符做处理,防止出现乱码,那么在MySQL里,为什么大家都使用utf8_ ...

  3. mysql中时间类型datetime,timestamp与int的区别

    在mysql中存储时间,我们可以用datetime 格式,timestamp格式,也可以用int格式.那么我们设计的时候该如何考虑呢? 首先,我觉得应该明白这几个格式究竟是如何的,然后看看他们的区别, ...

  4. Mysql中的排序规则utf8_unicode_ci、utf8_general_ci的区别总结

    Mysql中utf8_general_ci与utf8_unicode_ci有什么区别呢?在编程语言中,通常用unicode对中文字符做处理,防止出现乱码,那么在MySQL里,为什么大家都使用utf8_ ...

  5. MYSQL中的普通索引,主健,唯一,全文索引区别

    MYSQL索引用来快速地寻找那些具有特定值的记录,所有MySQL索引都以B-树的形式保存.如果没有索引,执行查询时MySQL必须从第一个记录开始扫描整个表的所有记录,直至找到符合要求的记录.表里面的记 ...

  6. MySql中的count、NULL和空串的区别

    **1.count (1).count (*) 与 count (列名) 的区别** 表 count(1) count(*) count (列名) 作用 统计表中的所有的记录数 会统计表中的所有的记录 ...

  7. 浅谈SQL Server、MySQL中char,varchar,nchar,nvarchar区别

    最近一次的面试中,被面试官问到varchar和nvarchar的区别,脑海里记得是定长和可变长度的区别,但却没能说出来.后来,在网上找了下网友总结的区别.在这里做个备忘录: 一,SQL Server中 ...

  8. MySQL中where和on,where和having 的区别

    where和on的区别 用到连接查询时on会常用到,我们以左连接为例,来了解on的作用. on是在生成临时表使用的条件,不管on子句的条件是否为真,其都会返回左表的数据,如果条件为真则右表对应的数据也 ...

  9. mysql中char,varchar与text类型的区别和选用

    关于char,varchar与text平时没有太在意,一般来说,可能现在大家都是用varchar.但是当要存储的内容比较大时,究竟是选择varchar还是text呢?不知道...... 于是去查阅了一 ...

  10. mysql中几个日期时间类型之间的区别和使用

    MySQL中有如下几个时间类型:date.time.datetime.timestamp.year MySQL数据类型           含义 date                     只存 ...

随机推荐

  1. java实体转json忽略属性

    1: import com.alibaba.fastjson.annotation.JSONField; fastjson 过滤指定字段 @JSONField(serialize=false)priv ...

  2. hdu 5748 Bellovin【最长上升子序列】

    题目链接:https://vjudge.net/contest/148584#problem/A 题目大意: 解题思路:题目要求为:输出与已知序列的每一个元素的f(i)(f(i)的定义如题)相同的字典 ...

  3. Couple number

    P1348 Couple number 我其实找规律了的,然后也没仔细分析,这个题多巧妙. C=a^2-b^2=(a+b)(a-b) 对于任意a而言,加减同一个数得到的数的奇偶性相同,故c=奇数或4的 ...

  4. 011.Docker仓库管理

    一 Docker仓库介绍 docker 仓库,即 registry,实现了镜像的管理.分发,同时还包括用户的认证.docker registry 仓库是一个无状态的.高可靠的服务器应用程序,用来存储d ...

  5. 深入理解 MySQL ——锁、事务与并发控制

    本文首发于vivo互联网技术微信公众号 mp.weixin.qq.com/s/JFSDqI5ya… 作者:张硕 本文对 MySQL 数据库中有关锁.事务及并发控制的知识及其原理做了系统化的介绍和总结, ...

  6. odoo 模型继承

    在odoo中有两种模型的继承机制(传统方式和委托继承方式) 重点:在__manifest__.py中找到depends,加上要继承的模块 'depends': ['account'] 注意继承的模型所 ...

  7. SQL sysobjects 表 详解

    sysobjects 表 在数据库内创建的每个对象(约束.默认值.日志.规则.存储过程等)在表中占一行.只有在 tempdb 内,每个临时对象才在该表中占一行. 列名 数据类型 描述 name sys ...

  8. BZOJ.3238.[AHOI2013]差异(后缀自动机 树形DP/后缀数组 单调栈)

    题目链接 \(Description\) \(Solution\) len(Ti)+len(Tj)可以直接算出来,每个小于n的长度会被计算n-1次. \[\sum_{i=1}^n\sum_{j=i+1 ...

  9. BZOJ.1022.[SHOI2008]小约翰的游戏John(博弈论 Anti-Nim)

    题目链接 Anti-Nim游戏: 先手必胜当且仅当: 1.所有堆的石子数为1,且异或和为0 2.至少有一堆石子数>1,且异或和不为0 简要证明: 对于1:若异或和为1,则有奇数堆:异或和为0,则 ...

  10. MIRUO面试题

    1.c#可以继承string类吗?2.接口可以实现接口吗?抽象类可以实现接口吗?抽象类可以实现实体类吗?3.用C#计算2.5的3次方的方法.4.什么是协同程序?5.GC是什么,如何减少内存,如何加快性 ...