1. 程式人生 > >inner join 和where 區別

inner join 和where 區別

1 .WHERE子句中使用的連線語句,在資料庫語言中,被稱為隱性連線。INNER JOIN……ON子句產生的連線稱為顯性連線。(其他JOIN引數也是顯性連線)WHERE 和INNER JOIN產生的連線關係,沒有本質區別,結果也一樣。但是!隱性連線隨著資料庫語言的規範和發展,已經逐漸被淘汰,比較新的資料庫語言基本上已經拋棄了隱性連線,全部採用顯性連線了。

2 .無論怎麼連線,都可以用join子句,但是連線同一個表的時候,注意要定義別名,否則產生錯誤!

a> inner join:理解為“有效連線”,兩張表中都有的資料才會顯示left join:理解為“有左顯示”,比如on a.field=b.field,則顯示a表中存在的全部資料及a//b中都有的資料,A中有、B沒有的資料以null顯示

b> right join:理解為“有右顯示”,比如on a.field=b.field,則顯示B表中存在的全部資料及a//b中都有的資料,B中有、A沒有的資料以null顯示

c> full join:理解為“全連線”,兩張表中所有資料都顯示,實際就是inner +(left-inner)+(right-inner)

3 .join可以分主次表   外聯接有三種類型:完全外聯,左聯,右聯.
完全外聯包含兩張表的所有記錄.
左聯是以左邊的表為主,右邊的為輔,右聯則相反

4.一般要使得資料庫查詢語句效能好點遵循一下原則:

  •    在做表與表的連線查詢時,大表在前,小表在
  • 不使用表別名,通過欄位字首區分不同表中的欄位
  • 查詢條件中的限制條件要寫在表連線條件前
  • 儘量使用索引的欄位做為查詢條件