zoukankan      html  css  js  c++  java
  • SQL多表联合查询(交叉连接,内连接,外连接)

    连接查询:              

      交叉连接:                    

    交叉连接返回的结果是被连接的两个表中所有数据行的笛卡尔积,也就是返回第一个表中符合查询条件的数据航数乘以第二个表中符合,查询条件的数据行数,例如department表中有4个部门,employee表中有4个员工,那么交叉连接的结果就有4 * 4 = 16条数据                

    SELECT * FROM 表1 CROSS JOIN 表2;
    SELECT * FROM 表1,表2;

     从上述描述情况可以看出,交叉连接的结果就是两个表中所有数据的组合。需要注意的是,在实际开发中这种业务需求是很少见的,一般不会使用交叉连接,而是使用具体的条件对数据进行有目的的查询

    内连接:
            内连接(INNER JOIN)又称简单连接或自然连接,是一种常见的连接查询。内连接使用比较运算符对两个表中的数据进行比较,并列出与连接条件匹配的数据航,组合成新的记录,也就是说在内连接查询中,只有满足条件的记录才能出现在查询结果中。

     SELECT 查询字段 FROM 表1 [INNER] JOIN 表2 ON 表1.关系字段 = 表2.关系字段;

         在上述语法格式中,INNER JOIN用于连接两个表,ON来指定连接条件,其中INNER可以省略。内连接其实还可以细分为如下两类:
          1.隐式内连接:顾名思义隐式的就是我们看不到inner join的关键字。而使用where关键字替代。        

     SELECT * FROM 表1,表2 where 表1.关系字段 = 表2.关系字段;

          2.显示内连接:显示的就是在语句中明显的调用了inner join的关键字    

    SELECT * FROM 表1 inner join 表2 on 表1.关系字段 = 表2.关系字段;
    SELECT * FROM 表1 join 表2 on 表1.关系字段 = 表2.关系字段;

      外连接:

        前面讲解的内连接查询中,返回的结果只包含符合查询条件和连接条件的数据,然而有时还需要包含没有关联的数据,即返回查询结果中不仅包含符合条件的数据,而且还包括左表(左连接或做外连接)、右表(右连接或右外连接)
         或两个表(全连接)中的所有数据,此时就需要使用外连接查询,外连接分为左连接和右连接。
                         语法格式:

      SELECT 所查字段 FROM 表1 LEFT|RIGHT [OUTER] JOIN 表2 ON 表1.关系字段 = 表2.关系字段 WHERE 条件;

                      外连接的语法格式和内连接类似,只不过使用的是LEFT JOIN、RIGHT JOIN关键字,其中关键字左边的表被称为左表,关键字右边的表被称为右表。

  • 相关阅读:
    注释驱动的 Spring cache 缓存介绍--转载
    AOP 的利器:ASM 3.0 介绍
    字符串比较报错
    Performing a thread dump in Linux or Windows--reference
    Linux 精准获取进程pid--转
    /bin/bash^M: bad interpreter: 没有那个文件或目录--转载
    linux 进程综合指令
    Sending e-mail with Spring MVC---reference
    Spring XD 1.1 M2 and 1.0.3 released---support kafka
    大数据框架对比:Hadoop、Storm、Samza、Spark和Flink——flink支持SQL,待看
  • 原文地址:https://www.cnblogs.com/deepSleeping/p/10012402.html
Copyright © 2011-2022 走看看