在本教程中,您將學(xué)習(xí)如何基于列值對(duì)行進(jìn)行分組。
GROUP BY子句與SELECT語(yǔ)句和聚合函數(shù)結(jié)合使用,以按通用列值將行分組在一起
為了容易理解這一點(diǎn),讓我們來(lái)看看下面employees和departments表。
+--------+--------------+------------+---------+ | emp_id | emp_name | hire_date | dept_id | +--------+--------------+------------+---------+ | 1 | Ethan Hunt | 2001-05-01 | 4 | | 2 | Tony Montana | 2002-07-15 | 1 | | 3 | Sarah Connor | 2005-10-18 | 5 | | 4 | Rick Deckard | 2007-01-03 | 3 | | 5 | Martin Blank | 2008-06-24 | NULL | +--------+--------------+------------+---------+ | +---------+------------------+ | dept_id | dept_name | +---------+------------------+ | 1 | Administration | | 2 | Customer Service | | 3 | Finance | | 4 | Human Resources | | 5 | Sales | +---------+------------------+ | |
表: employees | 表: departments |
現(xiàn)在,不只是查找雇員及其所在部門(mén)的名稱,而是要查找每個(gè)部門(mén)中的雇員總數(shù)。
對(duì)于小型表,您可以簡(jiǎn)單地應(yīng)用左聯(lián)接并計(jì)算雇員數(shù),但是假設(shè)如果一個(gè)表包含數(shù)千名雇員,那將不是那么容易。
在這種情況下,可以將GROUP BY子句與SELECT語(yǔ)句一起使用,如下所示:
SELECT t1.dept_name, count(t2.emp_id) AS total_employees FROM departments AS t1 LEFT JOIN employees AS t2 ON t1.dept_id = t2.dept_id GROUP BY t1.dept_name;
如果執(zhí)行上面的語(yǔ)句,您將獲得如下輸出:
+-------------------+-----------------+ | dept_name | total_employees | +-------------------+-----------------+ | Administration | 1 | | Customer Service | 0 | | Finance | 1 | | Human Resources | 1 | | Sales | 1 | +-------------------+-----------------+
在下一章中,您將學(xué)習(xí)如何使用HAVING子句和group BY子句為組或聚合指定搜索條件。