MySQL查詢之ON,WHERE,HAVING
執行順序:
on 早於 where 早於 having
上面是非常重要的知識點。
on where
意思就是當在多表連接的時候,on會先執行過濾,之後他們在做連接,這時候要是是左連接或右連接,那麼就會有多餘的null字段。
例子如下:
A表
B表
where 結果:
on 結果:
這是因爲on先執行了查詢生成臨時表,然後進行左連接。
where having
和on和where相反,where執行時間早於having。
SELECT xsno FROM (SELECT x.sno AS xsno, SUM(x.qty) AS xsum FROM spj X GROUP BY x.sno) AS temp WHERE xsum >(SELECT SUM(Y.qty) FROM spj Y WHERE Y.sno='s1')
簡化成
SELECT sno FROM spj GROUP BY sno HAVING SUM(qty) >(SELECT SUM(qty) FROM spj WHERE sno='s3')
這是因爲having可以篩選成組後的數據。
作用的對象不同。WHERE 子句作用於表和視圖,HAVING 子句作用於組。
WHERE 在分組和聚集計算之前選取輸入行(因此,它控制哪些行進入聚集計算), 而 HAVING 在分組和聚集之後選取分組的行。因此,WHERE 子句不能包含聚集函數; 因爲試圖用聚集函數判斷那些行輸入給聚集運算是沒有意義的。 相反,HAVING 子句總是包含聚集函數。(嚴格說來,你可以寫不使用聚集的 HAVING 子句, 但這樣做只是白費勁。同樣的條件可以更有效地用於 WHERE 階段。)