sql(join on 和where的执行顺序
left join :左連接,返回左表中所有的記錄以及右表中連接字段相等的記錄。
right join :右連接,返回右表中所有的記錄以及左表中連接字段相等的記錄。
inner join: 內(nèi)連接,又叫等值連接,只返回兩個(gè)表中連接字段相等的行。
full join:外連接,返回兩個(gè)表中的行:left join + right join。
cross join:結(jié)果是笛卡爾積,就是第一個(gè)表的行數(shù)乘以第二個(gè)表的行數(shù)。
關(guān)鍵字:?on
數(shù)據(jù)庫在通過連接兩張或多張表來返回記錄時(shí),都會(huì)生成一張中間的臨時(shí)表,然后再將這張臨時(shí)表返回給用戶。
在使用left?jion時(shí),on和where條件的區(qū)別如下:
1、?on條件是在生成臨時(shí)表時(shí)使用的條件,它不管on中的條件是否為真,都會(huì)返回左邊表中的記錄。
2、where條件是在臨時(shí)表生成好后,再對(duì)臨時(shí)表進(jìn)行過濾的條件。這時(shí)已經(jīng)沒有l(wèi)eft?join的含義(必須返回左邊表的記錄)了,條件不為真的就全部過濾掉。
假設(shè)有兩張表:
表1:tab2
| id | size |
| 1 | 10 |
| 2 | 20 |
| 3 | 30 |
表2:tab2
| size | name |
| 10 | AAA |
| 20 | BBB |
| 20 | CCC |
兩條SQL:
1、select?*?form?tab1?left?join?tab2?on?(tab1.size?=?tab2.size)?where?tab2.name=’AAA’
2、select?*?form?tab1?left?join?tab2?on?(tab1.size?=?tab2.size?and?tab2.name=’AAA’)
| 第一條SQL的過程: ?
? |
| 第二條SQL的過程: ?
? |
其實(shí)以上結(jié)果的關(guān)鍵原因就是left?join,right?join,full?join的特殊性,不管on上的條件是否為真都會(huì)返回left或right表中的記錄,full則具有l(wèi)eft和right的特性的并集。?而inner?jion沒這個(gè)特殊性,則條件放在on中和where中,返回的結(jié)果集是相同的。
轉(zhuǎn)載于:https://blog.51cto.com/marsng/1725639
總結(jié)
以上是生活随笔為你收集整理的sql(join on 和where的执行顺序的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 比尔·盖茨的名言名句227个
- 下一篇: oracle 11g-R2安装