SQL 联接(内连接/外连接/交叉连接)

SQL  联接

有表 titles(书信息表)  如下图

SQL 联接(内连接/外连接/交叉连接)_第1张图片

有表 publishers(出版社)  如下图

SQL 联接(内连接/外连接/交叉连接)_第2张图片

执行左外联接代码:

select titles.titles_id,titles.title,publishers.pub_name from titles left outer join publishers on titles.pub_id=publishers.pub_id     结果如下图:

大家看明白了吗? 现在要讲关左外联接的 理论了 要顶住呀!不带睡觉啊!

 

一、联接( join)

通过联接,可以根据各个表之间的逻辑关系从两个或多个表中检索数据。联接表示应如何使用一个表中的数据来选择另一个表中的行。

联接条件通过以下方法定义两个表在查询中的关联方式:

指定每个表中要用于联接的列。典型的联接条件在一个表中指定外键,在另一个表中指定与其关联的键。指定比较各列的值时要使用的逻辑运算符(=、<> 等)。

 

二、联接类型

当联接表时,创建的联接类型影响出现在结果集内的行。联接类型:

三、内联接

内连接也叫自然连接,它是组合两个表的常用方法。自然连接将两个表中的列进行比较,将两个表中满足连接条件的行组合起来,作为结果。自然连接有两种形式的语法。

语法一:

       SELECT  列   FROM  表1 [insert] JION 表2  ON 表1.列=表2.列

语法二:

        SELECT  列  FROM  表1,表2  WHERE表1.列=表2.列

【例】从titles、authors和titleauthor表中查询书的书号、书名、作者号和作者名。

 select titles.title_id, title, authors.au_id, au_lname from titles join titleauthor on titles.title_id=titleauthor.title_id  join authors  on authors.au_id=titleauthor.au_id

 

四、外连接(Outer join)

在自然连接中,只有在两个表中匹配的行才能在结果集中出现。而在外连接中可以只限制一个表,而对另外一个表不加限制(即所有的行都出现在结果集中)。

外连接分为左外连接、右外连接和全外连接。左外连接是对连接条件中左边的表不加限制;右外连接是对右边的表不加限制;全外连接对两个表都不加限制,所有两个表中的行都会包括在结果集中。

 

五、外连接(Outer join)语法

左外连接的语法为: SELECT 列 FROM 表1   LEFT   [OUTER]JOIN 表2 ON 表1.列1=表2.列2

右外连接的语法为: SELECT select_list FROM  表1 RIGHT[OUTER]JOIN 表2 ON 表1.列1=表2.列2

全外连接(完整外部联接)的语法为: SELECT select_list FROM  表1 FULL[OUTER]  JOIN  表2 ON 表1.列1=表2.列2

 

六、左向外联接

包括第一个命名表(“左”表,出现在 JOIN 子句的最左边)中的所有行。不包括右表中的不匹配行。

【例35】下面的 SQL 语句说明 titles 表和 publishers 表之间的左向外联接包括所有的书名,甚至包括那些没有出版商信息的书名: Use pubs    SELECT titles.title_id,    titles.title, publishers.pub_name    FROM titles LEFT OUTER JOIN publishers ON titles.pub_id = publishers.pub_id

 

 

 

七、右向外联接

包括第二个命名表(“右”表,出现在 JOIN 子句的最右边)中的所有行。不包括左表中的不匹配行。

【例36】在 titles 和 publishers 表之间的右向外联接将包括所有的出版商,甚至包括那些在 titles 表中没有书名的出版商。

   SELECT titles.title_id, titles.title, publishers.pub_name     FROM titles RIGHT OUTER JOIN publishers ON titles.pub_id = publishers.pub_id

 

 

 

 

八、完整外部联接

包括所有联接表中的所有行,不论它们是否匹配。

【例37】 titles 表和 publishers 表之间的完整外部联接显示所有书名和所有出版商,甚至包括那些在另一个表中没有匹配值的书名和出版商。

    SELECT titles.title_id, titles.title, publishers.pub_name  FROM titles FULL OUTER JOIN publishers    ON titles.pub_id = publishers.pub_id

 

 

 

九、交叉联接

没有 WHERE 子句的交叉联接将产生联接所涉及的表的笛卡尔积。第一个表的行数乘以第二个表的行数等于笛卡尔积结果集的大小。

【例39】 阅读以下程序:

   USE pubs    

 SELECT au_fname, au_lname, pub_name  FROM authors CROSS JOIN publishers  ORDER BY au_lname DESC       

说明:结果集包含 184 行(authors 有 23 行,publishers 有 8 行;23 乘以 8 等于 184)。           不过,如果添加一个 WHERE 子句,则交叉联接的作用将同内联接一样。

 

 

使用例子:(Oracle)

SELECT
    A.KAISEN_NO ,       --回線番号 
    decode(B.KAISEN_KBN ,1, '固定', 2, '移動', ''),   --回線区分
    decode(B.CHAKU_SEN_KBN , 0, '通常', 1, '着専', ''),   --着専区分
    A.KEIHI_BUSHO_CD,       --負担部署Code
    D.BUSHO_MEI,       --負担部署名称
    A.RIYO_BUSHO_CD,       --利用部署Code
    E.BUSHO_MEI,       --利用部署名称
    C.RIYOSHA_CD,                                     --利用者cd
    C.RIYOSHA_MEI,       --利用者名
    B.MIKAIYAKU_RIYU                                         --未解約理由

FROM
   T_UCHIWAKE_MEISAI A                               --内訳明細データ
   LEFT OUTER JOIN M_TEL_NUMBER B ON A.KAISEN_NO = B.KAISEN_NO                          --回線マスタ
   LEFT OUTER JOIN M_RIYOSHA C ON A.RIYOSHA_NAIBU_NO = C.RIYOSHA_NAIBU_CD               --利用者マスタ
   LEFT OUTER JOIN M_BUSHO D ON A.KEIHI_BUSHO_CD = D.BUSHO_CD                           --部署マスタ
   LEFT OUTER JOIN M_BUSHO E ON A.RIYO_BUSHO_CD  = E.BUSHO_CD                           --部署マスタ

WHERE
  A.SEIKYU_KINGAKU != 0 AND
  A.WARIBIKI_MAE_RYOKIN = 0 AND
  A.HOSEI_GO_SEIKYU_KINGAKU = 0 AND
  SUBSTR(TO_CHAR(A.RIYO_NEN_TSUKI), 1, 4) = '請求年'   AND
  SUBSTR(TO_CHAR(A.RIYO_NEN_TSUKI), 5, 2) = '請求月'   AND
  B.KAISEN_KBN ='回線種類'   AND
  B.CHAKU_SEN_KBN = '回線区分'
  
ORDER BY
   A.KAISEN_NO

你可能感兴趣的:(SQL 联接(内连接/外连接/交叉连接))