資料庫中的左連接和右連接的區別可以概括為一句話來表示即左連接where只影響右表,右連接where只影響到左表
【推薦課程:MySQL教學】
#資料庫中的左連接(left join)和右連接(right join)區別
左連接(Left Join)
select * from tbl1 Left Join tbl2 where tbl1.ID = tbl2.ID
左連接後的檢索結果是顯示tbl1的所有資料和tbl2中滿足where 條件的資料。
簡言之Left Join影響到的是右邊的表格
右連接(Right Join)
select * from tbl1 Right Join tbl2 where tbl1.ID = tbl2.ID
檢索結果是tbl2的所有數據和tbl1中滿足where 條件的數據。
簡言之 Right Join影響到的是左邊的表。
內連接(inner join)
select * FROM tbl1 INNER JOIN tbl2 ON tbl1.ID = tbl2.ID
它的功能和 select * from tbl1
,tbl2 where tbl1. id=tbl2.id
相同。
其他內容:
1、WHERE子句中使用的連結語句,在資料庫語言中,稱為隱性連結。 INNER JOIN……ON子句產生的連接稱為顯性連接。 (其他JOIN參數也是顯性連接)WHERE 和INNER JOIN產生的連接關係,沒有本質區別,結果也一樣。但是隱性連接隨著資料庫語言的規範和發展,已經逐漸被淘汰,比較新的資料庫語言基本上已經拋棄了隱性連接,全部採用顯性連接了。
2、無論怎麼連接,都可以用join子句,但是連接同一個表的時候,注意要定義別名,否則產生錯誤
(1)inner join:理解為“有效連接”,兩張表中都有的數據才會顯示left join:理解為“有左顯示”,比如on a.field=b.field,則顯示a表中存在的全部數據及a\\b中都有的數據,A中有、B沒有的數據以null顯示
(2) right join:理解為“有右顯示”,比如on a.field=b.field,則顯示B表中存在的全部數據及a\\b中都有的數據,B中有、A沒有的數據以null顯示
(3)full join:理解為“全連接”,兩張表中所有數據都顯示,實際上就是inner (left-inner) (right-inner)
3、join可以分主次表外聯接有三種:完全外聯,左聯,右聯。完全外聯包含兩張表的所有記錄,左聯是以左邊的表為主,右邊的為輔,右聯則相反
4、一般要使得數據庫查詢語句性能好點遵循以下原則:
在做表與表格的連接查詢時,大表在前,小表在
不使用表別名,透過欄位前綴區分不同表中的欄位
查詢條件中的限制條件要寫在表格連接條件前
盡量使用索引的欄位做為查詢條件
以上是資料庫左連接和右連接有什麼區別的詳細內容。更多資訊請關注PHP中文網其他相關文章!