Mysql內連接、左連接、右連接以及全連接查詢區別整理


一、內連接

關鍵字:inner join on

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

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

二、左連接

關鍵字: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。

三、右連接

關鍵字: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。

四、全連接

關鍵字: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; //有排序效果

五、區別

  1.內連接,顯示兩個表中有聯系的所有數據;

  2.左鏈接,以左表為參照,顯示所有數據;

  3.右鏈接,以右表為參照顯示數據;

  4.全連接,顯示兩個表中所有數據,除被合並的列以外元素值相等只顯示一行數據,值不等顯示多行數據。


免責聲明!

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



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