資料庫在通過連線兩張或多張表來返回記錄時,都會生成一張中間的臨時表,然後再將這張臨時表返回給使用者。
在使用left jion時,on和where條件的區別如下:
1、 on條件是在生成臨時表時使用的條件,它不管on中的條件是否為真,都會返回左邊表中的記錄。
2、where條件是在臨時表生成好後,再對臨時表進行過濾的條件。這時已經沒有left
join的含義(必須返回左邊表的記錄)了,條件不為真的就全部過濾掉。
其實以上結果的關鍵原因就是left join,right join,full
join的特殊性,不管on上的條件是否為真都會返回left或right表中的記錄,full則具有left和right的特性的並集。
而inner jion沒這個特殊性,則條件放在on中和where中,返回的結果集是相同的。
left join 中左表的全部記錄將全部被查詢顯示,on
後面的條件對它不起作用,除非再後面再加上where來進行篩選,這就是sql語句2了;由sql語句3可見,on後面的條件中,右表的限制條件將會起作用。
inner join 中on後面的限制條件將全部起作用,這與where的執行結果是一樣的。另外,where語句與inner
join確實能得到相同的結果,只是效率不同(這個我沒有測試過,不過我相信這個結論)。
left jion時,on和where條件的區別
在使用left jion時,on和where條件的區別如下 1 on條件是在生成臨時表時使用的條件,它不管on中的條件是否為真,都會返回左邊表中的記錄。2 where條件是在臨時表生成好後,再對臨時表進行過濾的條件。這時已經沒有left join的含義 必須返回左邊表的記錄 了,條件不為真的就全部過...
join連線表時是先join還是先where
left join 左連線,返回左表中所有的記錄以及右表中連線字段相等的記錄。right join 右連線,返回右表中所有的記錄以及左表中連線字段相等的記錄。inner join 內連線,又叫等值連線,只返回兩個表中連線字段相等的行。full join 外連線,返回兩個表中的行 left join ...
網路時延 傳送時延和傳播時延
一 時延的定義 時延是指乙個報文或分組從乙個網路的一端傳送到另乙個端所需要的時間。它包括了傳送時延,傳播時延,處理時延,排隊時延。時延 傳送時延 傳播時延 處理時延 排隊時延 一般,傳送時延與傳播時延是我們主要考慮的。對於報文長度較大的情況,傳送時延是主要矛盾 報文長度較小的情況,傳播時延是主要矛盾...