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後面,會有數據行數差別,比原來行數要多html

參考博客地址:ui

http://www.javashuo.com/article/p-wmbuphwi-br.htmlhtm

相關文章
相關標籤/搜索