left join后面加上where條件淺析


select a.*,b.*
from table1 a
left join table2 b on b.X=a.X
where XXX

如上:一旦使用了left join,沒有where條件時,左表table1會顯示全部內容

    使用了where,只有滿足where條件的記錄才會顯示(左表顯示部分或者全部不顯示)

so。。。。

left join的困惑:一旦加上where條件,則顯示的結果等於inner join 

 

原因分析:

數據庫在通過連接兩張或多張表來返回記錄時,都會生成一張中間的臨時表,然后再將這張臨時表返回給用戶;

where條件是在臨時表生成好后,再對臨時表進行過濾的條件;

因此:where 條件加上,已經沒有left join的含義(必須返回左邊表的記錄)了,條件不為真的就全部過濾掉。 

 

解決方案:

1、where過濾結果作為子查詢,和主表left,如下:

select a.*,tmp.*
from table1 a
left join(
    select a.*,b.*
    from table1 a
    left join table2 b on b.X=a.X
    where XXX
)tmp

很明顯,子查詢語句無論 left join、inner join都沒啥區別了

2、查詢條件放在on后面

select a.*,b.*
from table1 a
left join table2 b on b.X=a.X and XXX

注意:where XXX去掉,改為鏈接條件on后面的 and XXX

分析:

 on條件是在生成臨時表時使用的條件,它不管on中的條件是否為真,都會返回左邊表中的記錄。

 

結論:


 

過濾條件放在:

where后面:是先連接然生成臨時查詢結果,然后再篩選

on后面:先根據條件過濾篩選,再連 生成臨時查詢結果

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM