MySQL查詢之ON,WHERE,HAVING

MySQL查詢之ON,WHERE,HAVING

執行順序:
on 早於 where 早於 having

上面是非常重要的知識點。

on where

意思就是當在多表連接的時候,on會先執行過濾,之後他們在做連接,這時候要是是左連接或右連接,那麼就會有多餘的null字段。
例子如下:
A表

Alt text
B表

Alt text

where 結果:

Alt text

on 結果:

Alt text

這是因爲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 階段。)

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