連接查詢位置不同導致數據丟失

SELECT `t1`.`id` AS `device_id`, `t1`.`device_name`, SUM(`t2`.`ep_o`) AS `epo`
FROM `collect_device` AS `t1`
         LEFT OUTER JOIN `stat_hour` AS `t2` ON (((`t1`.`id` = `t2`.`collect_device_id`) AND
                                                  (`t2`.`stat_time` >= '2021-08-01 00:00:00')) AND
                                                 (`t2`.`stat_time` <= '2021-08-30 16:52:55.539177'))
WHERE ((`t1`.`calc_type` = 1) AND (`t1`.`energy_type` = 1))
GROUP BY `device_id`

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

過濾條件放在:

on後面:先根據條件過濾篩選,再連 生成臨時查詢結果
where後面:是先連接然生成臨時查詢結果,然後再篩選

個人理解,左連接on加的字段會查出所有數據,但是你where過濾掉了這個on查出來的。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章