詳解Mysql兩表 join 查詢方式

一、SQL基本語法格式

SELECT DISTINCT
	< select_list > 
FROM
	< left_table > < join_type >
JOIN < right_table > ON <join_condition>
WHERE
	< where_condition > 
GROUP BY
	< group_by_list > 
HAVING
	< having_condition > 
ORDER BY
	< order_by_condition > 
LIMIT < limit_number >

二、3種join方式

1. left join(左連接)

A left join B 得到A表的所有字段,如果沒有匹配到連接條件則用null填充

select A.*,B.* from A left join B on A.id = B.id;

2. right join(右連接)

A right join B 得到B表所有的字段

select A.*,B.* from A right join B on A.id=B.id;

3. inner join(內連接)

A inner join B得到(A和B的交集)

select A.*,B.* from A inner join B on A.id=B.id;

4. 在理解上面的三種join下,查詢(A –  A∩B)

select A.*,B.* from A left join B on A.id=B.id where B.id is null;

 5. 查詢 ( B – A∩B )

select A.*,B.* from A right join B on A.id=B.id where A.id is null;

 6. 查詢(A∪B – A∩B)

利用union去重將上面的第四、第五種兩條sql中間用union連接即可完成;即先完成一小部分的,然後將兩個拼起來的思想。

select A.*,B.* from A left join B on A.id=B.id where B.id is null
union
select A.*,B.* from A right join B on A.id=B.id where A.id is null;

 7. 查詢 AUB

MySQL中求並集可以使用union關鍵字進行處理(自動去重)

select A.*,B.* from A left join B on A.id=B.id
UNION
select A.*,B.* from A right join B on A.id=B.id;

到此這篇關於Mysql兩表 join 查詢方式的文章就介紹到這瞭,更多相關Mysql join 查詢內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: