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后面:先根據條件過濾篩選,再連 生成臨時查詢結果