zoukankan      html  css  js  c++  java
  • 数据库中的各种join的区别

    SQL JOIN 子句用于把来自两个或多个表的行结合起来,基于这些表之间的共同字段。

    最常见的 JOIN 类型:SQL INNER JOIN                                                --内连接

     LEFT JOIN、 RIGHT JOIN、 FULL JOIN                   --外链接

    cross join                                                                                                  --交叉连接

    left join -2

    right join -2

    full out join -2

    inner join

    id name
    1 Google
    2 淘宝
    3 微博
    4 Facebook

    table 1

    id address
    1 美国
    5 中国
    3 中国
    6 美国

     table 2

    一、INNER JOIN


    内连接是最常见的一种连接,只连接匹配的行。

    inner join语法

    select column_name(s)
    from table 1
    INNER JOIN table 2
    ON
    table 1.id=table 2.column_name

    注释:INNER JOIN与JOIN是相同

    INNER JOIN产生的结果集中,是1和2的交集。

    select * from Table A inner join Table B
    on Table A.id=Table B.id

     执行以上SQL输出结果如下:

    id name address
    1 Google 美国
    3 微博 中国

    二、LEFT JOIN


    LEFT JOIN返回左表的全部行和右表满足ON条件的行,如果左表的行在右表中没有匹配,那么这一行右表中对应数据用NULL代替。

    LEFT JOIN 语法

    select column_name(s)
    from table 1
    LEFT JOIN table 2
    ON table 1.column_name=table 2.column_name

    注释:在某些数据库中,LEFT JOIN 称为LEFT OUTER JOIN

    LEFT JOIN产生表1的完全集,而2表中匹配的则有值,没有匹配的则以null值取代。

    select * from Table A left join Table B
    on Table A.id=Table B.id

     执行以上SQL输出结果如下:

    id name address
    1 Google 美国
    2 淘宝 null
    3 微博 中国
    4 Facebook null

     三、RIGHT JOIN


    RIGHT JOIN返回右表的全部行和左表满足ON条件的行,如果右表的行在左表中没有匹配,那么这一行左表中对应数据用NULL代替。

    RIGHT JOIN语法

    select column_name(s)
    from table 1
    RIGHT JOIN table 2
    ON table 1.column_name=table 2.column_name

    注释:在某些数据库中,RIGHT JOIN 称为RIGHT OUTER JOIN

    RIGHT JOIN产生表2的完全集,而1表中匹配的则有值,没有匹配的则以null值取代。

    select * from Table A right join Table B
    on Table A.id=Table B.id

    执行以上SQL输出结果如下:

    id name address
    1 Google 美国
    5 null 中国
    3 微博 中国
    6 null 美国

    四、FULL OUTER JOIN


    FULL JOIN 会从左表 和右表 那里返回所有的行。如果其中一个表的数据行在另一个表中没有匹配的行,那么对面的数据用NULL代替

    FULL OUTER JOIN语法

    select column_name(s)
    from table 1
    FULL OUTER JOIN table 2
    ON table 1.column_name=table 2.column_name

    FULL OUTER JOIN产生1和2的并集。但是需要注意的是,对于没有匹配的记录,则会以null做为值。

    select * from Table A full outer join Table B
    on Table A.id=Table B.id

    执行以上SQL输出结果如下:

    id name address
    1 Google 美国
    2 淘宝 null
    3 微博 中国
    4 Facebook null
    5 null 中国
    6 null 美国

     五、CROSS JOIN

     

    如果不带WHERE条件子句,它将会返回被连接的两个表的笛卡尔积,返回结果的行数等于两个表行数的乘积;

    举例,下列A、B、C 执行结果相同,但是效率不一样:

    A:SELECT * FROM table1 CROSS JOIN table2

    B:SELECT * FROM table1,table2

    C:select * from table1 a inner join table2 b

    A:select a.*,b.* from table1 a,table2 b where a.id=b.id

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

    C:select * from table1 a inner join table2 b on a.id=b.id

    一般不建议使用方法A和B,因为如果有WHERE子句的话,往往会先生成两个表行数乘积的行的数据表然后才根据WHERE条件从中选择。

    因此,如果两个需要求交际的表太大,将会非常非常慢,不建议使用。

    MySQL中inner join 和 cross join 的区别?
    我用的MySQL 5.6
    只要使用相同的参数(同时使用on,或同时不使用),这两个命令并无区别。
    在网上看到很多人说,inner join 是取交集,而cross join是生成一个M*N项的笛卡尔积
    那是因为他们的语句都在inner join 后面加了一个on tableA.x = tableB.x,
    如果我在cross join 后面加上on tableA.x = tableB.x得到的同样是一样的结果啊?

    假设我们有两张表,Table A是左边的表,Table B是右边的表。

    上面的sql语句的执行结果相同

    复制于:https://www.cnblogs.com/reaptomorrow-flydream/p/8145610.html

  • 相关阅读:
    看了陈安之的文字 无论怎样 都要记住的是 你仍然是你自己 改变是应用他人的方法提高自己 改变是做更优秀更独特的自己
    流行的Ajax应用演示和源码下载(转)
    WEB2.0概念诠释(根据网络资料归纳)之一
    ASP.NET中文件上传下载方法集合(较为详细的介绍 转)
    建立梦想清单
    Ajax的应用
    Ajax的问题
    WEB2.0概念诠释(根据网络资料归纳)之三
    IIS突然挂掉
    VS2008软件90天过期,解决升级问题。
  • 原文地址:https://www.cnblogs.com/thomasbc/p/14411236.html
Copyright © 2011-2022 走看看