MySQL去重查詢GROUP BY的使用方法
當我們需要從MySQL數據庫中查詢數據并分組展示時,我們通常需要使用GROUP BY子句,同時,如果我們想在分組的結果中去重,可以使用DISTINCT關鍵字。接下來,我們將在實例中展示如何同時使用GROUP BY和DISTINCT來進行去重查詢。
實例說明:在MySQL的employees數據庫中,我們需要查詢每個部門的員工數量,同時去重員工名字。
第一步:選擇需要查詢的數據表和字段
我們需要查詢employees表中的dept_no和first_name字段,并對其進行分組和去重查詢。
SELECT dept_no, COUNT(DISTINCT first_name)
FROM employees
GROUP BY dept_no;
第二步:運行查詢語句并查看結果
運行上述SQL查詢語句,我們會得到以下結果:
+--------+-------------------------+
| dept_no| COUNT(DISTINCT first_name)|
+--------+-------------------------+
| d001 | 2368 |
| d002 | 2446 |
| d003 | 2330 |
| d004 | 2416 |
| d005 | 2204 |
| d006 | 2237 |
| d007 | 5225 |
| d008 | 2353 |
| d009 | 2393 |
+--------+-------------------------+
我們可以看到,查詢結果中將每個部門的員工數量分組展示,并對每個人去重,展示了每個部門獨特的員工數量。
補充說明:如何使用WHERE子句和HAVING子句
當我們需要對查詢結果中的數據進行過濾或限制時,可以使用WHERE子句或HAVING子句。其中,WHERE子句用于過濾查詢之前的數據,而HAVING子句用于過濾查詢的結果。
SELECT dept_no, COUNT(DISTINCT first_name)
FROM employees
WHERE last_name = 'Smith' -- 過濾last_name為Smith的員工
GROUP BY dept_no
HAVING COUNT(DISTINCT first_name) >1000; -- 篩選員工數大于1000人的部門
以上SQL語句將查詢employees表中last_name為Smith的員工,并統計每個部門中這類員工的數量,然后過濾出員工數大于1000的部門。
總結
在使用MySQL進行分組查詢時,我們可以通過DISTINCT關鍵字進行去重操作,同時還可以使用WHERE子句和HAVING子句來過濾和篩選查詢結果。掌握這些技能可以幫助我們更加高效地進行數據分析和處理。