数据库经常被用来回答这个问题,“某种类型的数据在表中出现的频率是多少?” 例如,你可能想知道你有多少只宠物,或者每个主人有多少只宠物,或者你可能想对你的动物进行各种普查操作。
计算你拥有的动物总数与“表格中有多少行
? ”是同一个问题。”pet
因为每只宠物只有一条记录。COUNT(*)
计算行数,因此计算动物数量的查询如下所示:
mysql> SELECT COUNT(*) FROM pet;
+----------+
| COUNT(*) |
+----------+
| 9 |
+----------+
早些时候,您检索了养宠物的人的姓名。COUNT()
如果你想知道每个主人有多少只宠物,
你可以使用:
mysql> SELECT owner, COUNT(*) FROM pet GROUP BY owner;
+--------+----------+
| owner | COUNT(*) |
+--------+----------+
| Benny | 2 |
| Diane | 2 |
| Gwen | 3 |
| Harold | 2 |
+--------+----------+
前面的查询用于GROUP BY
对每个 的所有记录进行分组owner
。COUNT()
结合使用
对于
GROUP BY
在各种分组下表征数据很有用。以下示例显示了执行动物普查操作的不同方法。
每个物种的动物数量:
mysql> SELECT species, COUNT(*) FROM pet GROUP BY species;
+---------+----------+
| species | COUNT(*) |
+---------+----------+
| bird | 2 |
| cat | 2 |
| dog | 3 |
| hamster | 1 |
| snake | 1 |
+---------+----------+
每个性别的动物数量:
mysql> SELECT sex, COUNT(*) FROM pet GROUP BY sex;
+------+----------+
| sex | COUNT(*) |
+------+----------+
| NULL | 1 |
| f | 4 |
| m | 4 |
+------+----------+
(在此输出中,NULL
表示性别未知。)
每个物种和性别组合的动物数量:
mysql> SELECT species, sex, COUNT(*) FROM pet GROUP BY species, sex;
+---------+------+----------+
| species | sex | COUNT(*) |
+---------+------+----------+
| bird | NULL | 1 |
| bird | f | 1 |
| cat | f | 1 |
| cat | m | 1 |
| dog | f | 1 |
| dog | m | 2 |
| hamster | f | 1 |
| snake | m | 1 |
+---------+------+----------+
使用 时不需要检索整个表
COUNT()
。例如,前面的查询,当只对狗和猫执行时,看起来像这样:
mysql> SELECT species, sex, COUNT(*) FROM pet
WHERE species = 'dog' OR species = 'cat'
GROUP BY species, sex;
+---------+------+----------+
| species | sex | COUNT(*) |
+---------+------+----------+
| cat | f | 1 |
| cat | m | 1 |
| dog | f | 1 |
| dog | m | 2 |
+---------+------+----------+
或者,如果您只想知道性别的动物的每个性别的动物数量:
mysql> SELECT species, sex, COUNT(*) FROM pet
WHERE sex IS NOT NULL
GROUP BY species, sex;
+---------+------+----------+
| species | sex | COUNT(*) |
+---------+------+----------+
| bird | f | 1 |
| cat | f | 1 |
| cat | m | 1 |
| dog | f | 1 |
| dog | m | 2 |
| hamster | f | 1 |
| snake | m | 1 |
+---------+------+----------+
如果除了
COUNT()
值之外还命名要选择的列,则GROUP
BY
应该存在一个子句来命名这些相同的列。否则,会发生以下情况:
如果
ONLY_FULL_GROUP_BY
开启SQL模式,会报错:mysql> SET sql_mode = 'ONLY_FULL_GROUP_BY'; Query OK, 0 rows affected (0.00 sec) mysql> SELECT owner, COUNT(*) FROM pet; ERROR 1140 (42000): In aggregated query without GROUP BY, expression #1 of SELECT list contains nonaggregated column 'menagerie.pet.owner'; this is incompatible with sql_mode=only_full_group_by
如果
ONLY_FULL_GROUP_BY
未启用,则通过将所有行视为一个组来处理查询,但为每个命名列选择的值是不确定的。服务器可以自由地从任何行中选择值:mysql> SET sql_mode = ''; Query OK, 0 rows affected (0.00 sec) mysql> SELECT owner, COUNT(*) FROM pet; +--------+----------+ | owner | COUNT(*) | +--------+----------+ | Harold | 8 | +--------+----------+ 1 row in set (0.00 sec)
另见第 12.20.3 节,“MySQL 对 GROUP BY 的处理”。
有关行为和相关优化
的信息
,请参阅
第 12.20.1 节,“聚合函数描述” 。COUNT(
expr
)