Where和having都是條件篩選關鍵字,它們有什么分別?


WHERE是在數據分組前進行條件過濾, HAVING子句是在數據分組后進行條件過濾,WHERE子句中不能使用聚合函數,HAVING子句可以使用聚合函數

 

需要注意說明當同時含有where子句、group by 子句 、having子句及聚集函數時執行順序如下

A、執行where子句查找符合條件的數據

B、函數計算每一組的值最后用having 子句去掉不符合條件的組

C、having 子句中的每一個元素也必須出現在select列表中有些數據庫例外oracle.

D、having子句和where子句都可以用來設定限制條件以使查詢結果滿足一定的條件限制

E、having子句限制的是組而不是行。where子句中不能使用聚集函數having子句中可以

 

 

1求平均工資大於2000的部門 
  select dept_id,avg(salary) from s_emp group by dept_id having avg(salary)>2000;

 

 

 

例子2:查詢求各個部門的最小最高工資之和部門名稱 
select e.dept_id,d.name,min(salary),max(salary),sum(salary) from s_emp e ,s_dept d where e.dept_id=d.id group by e.dept_id,d.name;

 

 

 

使用group by 常見的錯誤
如果在select語句中沒有出現group by子句那么不能在select子句中同時出現單個列名和組函數的混合現象

如果希望限制分組中的數據那么可以使用having子句而不能使用where子句having中可以出現組函數而where不能出現組函數


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM