Mysql的內連接、左連接、右連接以及全連接查詢


轉載:https://blog.csdn.net/zjt980452483/article/details/82945663

一、內連接查詢  inner join

關鍵字:inner  join   on

語句select * from a_table a inner join b_table b on a.a_id = b.b_id;

說明:組合兩個表中的記錄,返回關聯字段相符的記錄,也就是返回兩個表的交集(陰影)部分。

案例解釋:在boy表和girl 表中查出兩表 hid 字段一致的姓名(gname,bname),boy表和girl 表如下:

      

采用內連接查詢方式:

SELECT boy.hid,boy.bname,girl.gname FROM boy INNER JOIN girl ON girl.hid = boy.hid;

查詢結果如下:

二、左連接查詢 left join

關鍵字:left join on / left outer join on

語句:SELECT  * FROM a_table a left join b_table b ON a.a_id = b.b_id;

說明: left join 是left outer join的簡寫,它的全稱是左外連接,是外連接中的一種。 左(外)連接,左表(a_table)的記錄將會全部表示出來,而右表(b_table)只會顯示符合搜索條件的記錄。右表記錄不足的地方均為NULL。

案例解釋:在boy表和girl 表中左連接查詢,boy表和girl 表如下:

      

采用內連接查詢方式:

SELECT boy.hid,boy.bname,girl.gname FROM boy LEFT JOIN girl ON girl.hid = boy.hid;

查詢結果如下:

三、右連接 right join

關鍵字:right join on / right outer join on

語句:SELECT  * FROM a_table a right outer join b_table b on a.a_id = b.b_id;

說明:right join是right outer join的簡寫,它的全稱是右外連接,是外連接中的一種。與左(外)連接相反,右(外)連接,左表(a_table)只會顯示符合搜索條件的記錄,而右表(b_table)的記錄將會全部表示出來。左表記錄不足的地方均為NULL。

案例解釋:在boy表和girl 表中右連接查詢,boy表和girl 表如下:

      

采用內連接查詢方式:

SELECT boy.hid,boy.bname,girl.gname FROM boy RIGHT JOIN girl ON girl.hid = boy.hid;

查詢結果如下:

四、全連接 union

關鍵字:union /union all

語句:(select colum1,colum2...columN from tableA ) union (select colum1,colum2...columN from tableB )

         或 (select colum1,colum2...columN from tableA ) union all (select colum1,colum2...columN from tableB );

union語句注意事項:

         1.通過union連接的SQL它們分別單獨取出的列數必須相同;

         2.不要求合並的表列名稱相同時,以第一個sql 表列名為准;

         3.使用union 時,完全相等的行,將會被合並,由於合並比較耗時,一般不直接使用 union 進行合並,而是通常采用union all 進行合並;

         4.被union 連接的sql 子句,單個子句中不用寫order by ,因為不會有排序的效果。但可以對最終的結果集進行排序;

           (select id,name from A order by id) union all (select id,name from B order by id); //沒有排序效果

           (select id,name from A ) union all (select id,name from B ) order by id; //有排序效果

案例解釋:將a表和b表合並,表結構如下:

          

采用 union 全連接:

union會自動將完全重復的數據去除掉,a、b表中"c"的值都為15,所以只顯示一行。

采用 union all 全連接:

union all會保留那些重復的數據;

左右連接練習題:

根據給出的表結構按要求寫出SQL語句。t 表(即Team表)和 m 表(即Match表) 的結構如下:

     

t 表(即Team表)和 m 表(即Match表) 的內容如下:

         

t 表和 m 表下載地址

m 表(即Match表) 的 hostTeamID 與 guestTeamID 都與 t 表(即Team表) 中的 teamID 關聯。請查出 2006-6-1 到2006-7-1之間舉行的所有比賽,並且用以下形式列出: 拜仁   2:0  不來梅  2006-6-21

===============================================================================

解決方案:

第一步:先以 m 表左連接 t 表,查出 m 表中 hid 這列對應的比賽信息:

SELECT m.mid,t.tname,m.mres,m.matime as time FROM m LEFT JOIN t ON t.tid = m.hid;

查詢結果記為結果集 t1 ,t1 表如下:

第二步:先以 m 表左連接 t 表,查出 m 表中 gid 這列對應的比賽信息:

SELECT m.mid,t.tname,m.mres,m.matime FROM m LEFT JOIN t ON t.tid = m.gid;

查詢結果記為結果集 t2 ,t2 表如下:

第三步:以結果集 t1 為基礎左連接查詢結果集 t2,查詢條件為兩者比賽序號(mid)相同。

  1.  
    SELECT t1.tname,t1.mres,t2.tname,t1.time FROM
  2.  
    ( SELECT m.mid,t.tname,m.mres,m.matime as time FROM m LEFT JOIN t ON t.tid = m.hid)
  3.  
    as t1
  4.  
    LEFT JOIN
  5.  
    ( SELECT m.mid,t.tname,m.mres,m.matime as time FROM m LEFT JOIN t ON t.tid = m.gid)
  6.  
    as t2
  7.  
    ON t1.mid = t2.mid WHERE t1.time BETWEEN '2006-06-01' AND '2006-07-01';

查詢結果如下:

全連接練習題:

A表和B表結構如下,請將兩表合並:

            

合並要求:A表中a:5,B表中a:5,因此合並后表中a對應的值為10;要求查出的結果樣本如下:

采用 union all 全連接,然后使用from 子查詢:

SELECT id,SUM(num) as num FROM ((SELECT id,num FROM a) UNION ALL(SELECT id,num FROM b)) as tb GROUP BY id;

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM