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

left join on和where區別

left join中關於where和on條件的幾個知識點:
    1.多表left join是會生成一張臨時表,並返回給使用者
    2.where條件是針對最後生成的這張臨時表進行過濾,過濾掉不符合where條件的記錄,是真正的不符合就過濾掉。
    3.on條件是對left join的右表進行條件過濾,但依然返回左表的所有行,右表中沒有的補為NULL
    4.on條件中如果有對左表的限制條件,無論條件真假,依然返回左表的所有行,但是會影響右表的匹配值。也就是說on中左表的限制條件隻影響右表的匹配內容,不影響返回行數。
結論:
    1.where條件中對左表限制,不能放到on後面
    2.where條件中對右表限制,放到on後面,會有資料行數差異,比原來行數要多

參考部落格地址:

https://www.cnblogs.com/cuisi/p/7685893.ht