mysql left join 用法說明

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/wang666/p/9887631.html

explain命令解釋:
https://mp.weixin.qq.com/s?__biz=MzI2MTIzMzY3Mw==&mid=2247488432&idx=1&sn=87a3419d236834d829edcbd1b0812de9&chksm=ea5cded6dd2b57c0cab60b9db37962fafea34e2bde3683751fe25132de68f1f1d1d4850355c4&mpshare=1&scene=1&srcid=&key=08a30349bc08b47fe9252f64ccbad5ce49d5ecdca6a5d9bc7c33596a3a9f5b516398d4169e6240f0141d67517c4d4246b227da5b32a00178ae7a98f1737757382ce81cd4e30d4423b2904dcd131ace7b&ascene=1&uin=MjU0ODA2ODgwNw%3D%3D&devicetype=Windows+10&version=62060833&lang=zh_CN&pass_ticket=zyaTH2hBRYvaMTmr8Vycs6f8VWECJQPak3KZtjQYhOxUsULCfNyGDypyFskTGcBg
相關文章
相關標籤/搜索