zoukankan      html  css  js  c++  java
  • Mysql之inner join,left join,right join详解

    首先借用官方的解释下:

    inner join(等值连接):只返回两个表中联结字段相等的行;

    left join(左联接):返回包括左表中的所有记录和右表中联结字段相等的记录;

    right join(右联接):返回包括右表中的所有记录和左表中联结字段相等的记录。

    比如我们有table1、table2两个表

    table1表                                 table2表
    
    ---------------                  ----------------------
    
    id     name                     id      score
    
    1      lee                      1       90
    
    2      zhang                    2       100
    4      wang                     3       70

      

    Sql代码

    create table table1(id int,name varchar(10));
    create table table2(id int,score int);
    
     
    
    INSERT INTO table1 (id,NAME) VALUES ('1','lee'),('2','zhang'),('4','wang');
    
    INSERT INTO table2 (id,score) VALUES ('1',90),('2',100),('3',70);
    

      

      

    以下均在查询分析器中执行

    一、外连接
    1.概念:包括左向外联接、右向外联接或完整外部联接

    2.左连接:left join 或 left outer join
    (1)左向外联接的结果集包括 LEFT OUTER 子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值(null)。
    (2)sql 语句

    select * from table1 left join table2 on table1.id=table2.id;

    -------------结果-------------

    注释:包含table1的所有子句,根据指定条件返回table2相应的字段,不符合的以null显示

    3.右连接:right join 或 right outer join
    (1)右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。
    (2)sql 语句

    select * from table1 right join table2 on table1.id=table2.id;

    -------------结果-------------

    注释:包含table2的所有子句,根据指定条件返回table1相应的字段,不符合的以null显示

    4.完整外部联接:full join 或 full outer join
    (1)完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。
    (2)sql 语句

    select * from table1 full join table2 on table1.id=table2.id;

    -------------结果-------------
    idnameidscore
    ------------------------------
    1lee190
    2zhang2100
    4wangNULLNULL
    NULLNULL370
    ------------------------------
    注释:返回左右连接的和(见上左、右连接)

    二、内连接
    1.概念:内联接是用比较运算符比较要联接列的值的联接

    2.内连接:join 或 inner join

    3.sql 语句

    select * from table1 join table2 on table1.id=table2.id;

    -------------结果-------------

    注释:只返回符合条件的table1和table2的列

    4.等价(与下列执行效果相同)

    A:select a.*,b.* from table1 a,table2 b where a.id=b.id;
    
    B:select * from table1 cross join table2 where table1.id=table2.id; (注:cross join后加条件只能用where,不能用on)
    

      

    三、交叉连接(完全)

    1.概念:没有 WHERE 子句的交叉联接将产生联接所涉及的表的笛卡尔积。第一个表的行数乘以第二个表的行数等于笛卡尔积结果集的大小。(table1和table2交叉连接产生3*3=9条记录)

    2.交叉连接:cross join (不带条件where...)

    3.sql语句

    select * from table1 cross join table2;

    -------------结果-------------

    注释:返回3*3=9条记录,即笛卡尔积

    4.等价(与下列执行效果相同)

    A:select * from table1,table2;
    

      

  • 相关阅读:
    php底层HashTable的实现
    【问底】徐汉彬:PHP7和HHVM的性能之争
    linux查找系统中占用磁盘空间最大的文件
    深入理解Yii2.0(yii学习的经典博客)
    梦想天空(关注前端开发技术 html5+css3)
    风雪之隅(Laruence PHP开发组成员, Zend兼职顾问, Yaf, Yar, Yac, Opcache等项目作者、维护者.)
    阿里云收集服务器性能指标的python脚本
    简单5步,释放Mac磁盘空间
    我是如何自学Android,资料分享(2015 版)
    查询tensorflow中的函数用法
  • 原文地址:https://www.cnblogs.com/wicub/p/5328755.html
Copyright © 2011-2022 走看看