mysql如何查询并统计数量

62次阅读
没有评论

共计 5374 个字符,预计需要花费 14 分钟才能阅读完成。

这篇文章主要介绍 mysql 如何查询并统计数量,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

在 mysql 中,可以使用 SELECT 语句查询数据,并利用 COUNT() 函数统计查询结果的数量,语法“SELECT COUNT(*) FROM 表名 […];”或“SELECT COUNT(字段名) FROM 表名 […];”。

本教程操作环境:windows7 系统、mysql8 版本、Dell G3 电脑。

在 mysql 中,可以使用 SELECT 语句查询数据,并利用 COUNT() 函数统计查询结果的数量。

SELECT 的语法格式如下:

SELECT
{* |  字段列名}
FROM  表  1 ,  表  2 …
[WHERE  表达式 
[GROUP BY  group by definition 
[HAVING  expression  [{ operator   expression}…]]
[ORDER BY  order by definition]
[LIMIT[ offset ,]  row count ]
]

其中,各条子句的含义如下:

{*| 字段列名} 包含星号通配符的字段列表,表示所要查询字段的名称。

表 1,表 2 …,表 1 和表 2 表示查询数据的来源,可以是单个或多个。

WHERE 表达式 是可选项,如果选择该项,将限定查询数据必须满足该查询条件。

GROUP BY 字段,该子句告诉 MySQL 如何显示查询出来的数据,并按照指定的字段分组。

[ORDER BY 字段],该子句告诉 MySQL 按什么样的顺序显示查询出来的数据,可以进行的排序有升序(ASC)和降序(DESC),默认情况下是升序。

[LIMIT[ offset,] row count ],该子句告诉 MySQL 每次显示查询出来的数据条数。

COUNT() 函数统计数据表中包含的记录行的总数,或者根据查询结果返回列中包含的数据行数

COUNT(*) 计算表中总的行数,无论某列有数值或者为空值。

COUNT(表达式) 计算不包含 NULL 值的行数。

COUNT(DISTINCT 表达式) 返回不包含 NULL 值的唯一行数

COUNT() 函数的返回类型为 BIGINT。如果没有找到匹配的行,则 COUNT() 函数返回 0。

MySQL COUNT 示例

我们来创建一个名为 demo 的新表,并插入一些示例数据。

USE testdb;
-- create a demos table
CREATE TABLE IF NOT EXISTS demos(
 id int auto_increment primary key,
 val int 
-- insert some sample data
INSERT INTO demos(val)
VALUES(1),(1),(2),(2),(NULL),(3),(4),(NULL),(5);
-- select data from demos table
SELECT * FROM demos;

执行上面查询语句,得到以下结果 –

+----+------+
| id | val |
+----+------+
| 1 | 1 |
| 2 | 1 |
| 3 | 2 |
| 4 | 2 |
| 5 | NULL |
| 6 | 3 |
| 7 | 4 |
| 8 | NULL |
| 9 | 5 |
+----+------+
9 rows in set

要计算 demos 表中的所有行,请使用 COUNT(*) 函数,如下所示:

mysql  SELECT COUNT(*) FROM demos;
+----------+
| COUNT(*) |
+----------+
| 9 |
+----------+
1 row in set

您可以添加一个 WHERE 子句来指定一个条件来计数,例如,只计算 val 列包含值等于 2 的行,使用以下查询:

mysql  SELECT COUNT(*) FROM demos WHERE val = 2;
+----------+
| COUNT(*) |
+----------+
| 2 |
+----------+
1 row in set

如果在 COUNT 函数中指定 val 列,则 COUNT 函数计数其 val 列仅包含非 NULL 值的所有行。请参阅以下查询:

SELECT COUNT(*) FROM demos WHERE val = 2;

val 列中的两个 NULL 值将被忽略。

要计算 demos 表中的唯一行,可以将 DISTINCT 运算符添加到 COUNT 函数中,如下查询语句:

SELECT COUNT(DISTINCT val) FROM demos;

执行上面查询语句,得到以下结果 –

mysql  SELECT COUNT(DISTINCT val) FROM demos;
+---------------------+
| COUNT(DISTINCT val) |
+---------------------+
| 5 |
+---------------------+
1 row in set

在计数中忽略两个重复值 1,2 和两个 NULL 值。

具有 GROUP BY 的 MySQL COUNT

我们经常将 COUNT 函数与 GROUP BY 子句结合使用来统计不同分组中的数据。请参见以下 products 表的结构 –

mysql  desc products;
+--------------------+---------------+------+-----+---------+------------------+
| Field | Type | Null | Key | Default | Extra |
+--------------------+---------------+------+-----+---------+------------------+
| productCode | varchar(15) | NO | PRI | | |
| productName | varchar(70) | NO | MUL | NULL | |
| productLine | varchar(50) | NO | MUL | NULL | |
| productScale | varchar(10) | NO | | NULL | |
| productVendor | varchar(50) | NO | | NULL | |
| productDescription | text | NO | | NULL | |
| quantityInStock | smallint(6) | NO | | NULL | |
| buyPrice | decimal(10,2) | NO | | NULL | |
| MSRP | decimal(10,2) | NO | | NULL | |
| stockValue | double | YES | | NULL | STORED GENERATED |
+--------------------+---------------+------+-----+---------+------------------+
10 rows in set

例如,要查找每个产品系列中的产品数量,可以使用 COUNT 函数与 GROUP BY 子句,如下查询所示:

SELECT productline, count(*) FROM products GROUP BY productline;

执行上面代码,得到以下结果 –

mysql  SELECT productline, count(*) FROM products GROUP BY productline;
+------------------+----------+
| productline | count(*) |
+------------------+----------+
| Classic Cars | 38 |
| Motorcycles | 13 |
| Planes | 12 |
| Ships | 9 |
| Trains | 3 |
| Trucks and Buses | 11 |
| Vintage Cars | 24 |
+------------------+----------+
7 rows in set

要查找供应商提供的产品数量,请使用以下查询:

SELECT productvendor, count(*) FROM products GROUP BY productvendor;

执行上面代码,得到以下结果 –

mysql  SELECT productvendor, count(*) FROM products GROUP BY productvendor;
+---------------------------+----------+
| productvendor | count(*) |
+---------------------------+----------+
| Autoart Studio Design | 8 |
| Carousel DieCast Legends | 9 |
| Classic Metal Creations | 10 |
| Exoto Designs | 9 |
| Gearbox Collectibles | 9 |
| Highway 66 Mini Classics | 9 |
| Min Lin Diecast | 8 |
| Motor City Art Classics | 9 |
| Red Start Diecast | 7 |
| Second Gear Diecast | 8 |
| Studio M Art Models | 8 |
| Unimax Art Galleries | 8 |
| Welly Diecast Productions | 8 |
+---------------------------+----------+
13 rows in set

要查找哪个供应商提供至少 9 个产品,您可以使用 HAVING 子句在 COUNT 函数中,如以下查询语句所示:

SELECT productvendor, count(*) FROM products GROUP BY productvendor
HAVING count(*)  = 9;

执行上面代码,得到以下结果 –

mysql  SELECT productvendor, count(*) FROM products GROUP BY productvendor
HAVING count(*)  = 9;
+--------------------------+----------+
| productvendor | count(*) |
+--------------------------+----------+
| Carousel DieCast Legends | 9 |
| Classic Metal Creations | 10 |
| Exoto Designs | 9 |
| Gearbox Collectibles | 9 |
| Highway 66 Mini Classics | 9 |
| Motor City Art Classics | 9 |
+--------------------------+----------+
6 rows in set

MySQL COUNT IF

可以使用 COUNT 函数中的控制流程功能,例如 IF,IFNULL,CASE 等来计数其值与条件匹配的行。

例如,以下查询可以查找有多少被取消,暂停和有争议的订单:

SELECT COUNT(IF(status= Cancelled ,1, NULL))  Cancelled ,
 COUNT(IF(status= On Hold ,1, NULL))  On Hold ,
 COUNT(IF(status= Disputed ,1, NULL))  Disputed 
FROM orders;

执行上面代码,得到以下结果 –

mysql  SELECT COUNT(IF(status= Cancelled ,1, NULL))  Cancelled ,
 COUNT(IF(status= On Hold ,1, NULL))  On Hold ,
 COUNT(IF(status= Disputed ,1, NULL))  Disputed 
FROM orders;
+-----------+---------+----------+
| Cancelled | On Hold | Disputed |
+-----------+---------+----------+
| 6 | 4 | 3 |
+-----------+---------+----------+
1 row in set

如果订单的状态被取消,保留或有争议,IF 函数将返回 1,否则返回 NULL。COUNT 函数只计数 1,而不是 NULL 值,因此查询根据相应的状态返回订单数。

以上是“mysql 如何查询并统计数量”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注丸趣 TV 行业资讯频道!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-17发表,共计5374字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)