共計 5374 個字符,預(yù)計需要花費 14 分鐘才能閱讀完成。
這篇文章主要介紹 mysql 如何查詢并統(tǒng)計數(shù)量,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!
在 mysql 中,可以使用 SELECT 語句查詢數(shù)據(jù),并利用 COUNT() 函數(shù)統(tǒng)計查詢結(jié)果的數(shù)量,語法“SELECT COUNT(*) FROM 表名 […];”或“SELECT COUNT(字段名) FROM 表名 […];”。
本教程操作環(huán)境:windows7 系統(tǒng)、mysql8 版本、Dell G3 電腦。
在 mysql 中,可以使用 SELECT 語句查詢數(shù)據(jù),并利用 COUNT() 函數(shù)統(tǒng)計查詢結(jié)果的數(shù)量。
SELECT 的語法格式如下:
SELECT
{* | 字段列名}
FROM 表 1 , 表 2 …
[WHERE 表達(dá)式
[GROUP BY group by definition
[HAVING expression [{ operator expression}…]]
[ORDER BY order by definition]
[LIMIT[ offset ,] row count ]
]
其中,各條子句的含義如下:
{*| 字段列名} 包含星號通配符的字段列表,表示所要查詢字段的名稱。
表 1,表 2 …,表 1 和表 2 表示查詢數(shù)據(jù)的來源,可以是單個或多個。
WHERE 表達(dá)式 是可選項,如果選擇該項,將限定查詢數(shù)據(jù)必須滿足該查詢條件。
GROUP BY 字段,該子句告訴 MySQL 如何顯示查詢出來的數(shù)據(jù),并按照指定的字段分組。
[ORDER BY 字段],該子句告訴 MySQL 按什么樣的順序顯示查詢出來的數(shù)據(jù),可以進(jìn)行的排序有升序(ASC)和降序(DESC),默認(rèn)情況下是升序。
[LIMIT[ offset,] row count ],該子句告訴 MySQL 每次顯示查詢出來的數(shù)據(jù)條數(shù)。
COUNT() 函數(shù)統(tǒng)計數(shù)據(jù)表中包含的記錄行的總數(shù),或者根據(jù)查詢結(jié)果返回列中包含的數(shù)據(jù)行數(shù)
COUNT(*) 計算表中總的行數(shù),無論某列有數(shù)值或者為空值。
COUNT(表達(dá)式) 計算不包含 NULL 值的行數(shù)。
COUNT(DISTINCT 表達(dá)式) 返回不包含 NULL 值的唯一行數(shù)
COUNT() 函數(shù)的返回類型為 BIGINT。如果沒有找到匹配的行,則 COUNT() 函數(shù)返回 0。
MySQL COUNT 示例
我們來創(chuàng)建一個名為 demo 的新表,并插入一些示例數(shù)據(jù)。
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;
執(zhí)行上面查詢語句,得到以下結(jié)果 –
+----+------+
| 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(*) 函數(shù),如下所示:
mysql SELECT COUNT(*) FROM demos;
+----------+
| COUNT(*) |
+----------+
| 9 |
+----------+
1 row in set
您可以添加一個 WHERE 子句來指定一個條件來計數(shù),例如,只計算 val 列包含值等于 2 的行,使用以下查詢:
mysql SELECT COUNT(*) FROM demos WHERE val = 2;
+----------+
| COUNT(*) |
+----------+
| 2 |
+----------+
1 row in set
如果在 COUNT 函數(shù)中指定 val 列,則 COUNT 函數(shù)計數(shù)其 val 列僅包含非 NULL 值的所有行。請參閱以下查詢:
SELECT COUNT(*) FROM demos WHERE val = 2;
val 列中的兩個 NULL 值將被忽略。
要計算 demos 表中的唯一行,可以將 DISTINCT 運算符添加到 COUNT 函數(shù)中,如下查詢語句:
SELECT COUNT(DISTINCT val) FROM demos;
執(zhí)行上面查詢語句,得到以下結(jié)果 –
mysql SELECT COUNT(DISTINCT val) FROM demos;
+---------------------+
| COUNT(DISTINCT val) |
+---------------------+
| 5 |
+---------------------+
1 row in set
在計數(shù)中忽略兩個重復(fù)值 1,2 和兩個 NULL 值。
具有 GROUP BY 的 MySQL COUNT
我們經(jīng)常將 COUNT 函數(shù)與 GROUP BY 子句結(jié)合使用來統(tǒng)計不同分組中的數(shù)據(jù)。請參見以下 products 表的結(jié)構(gòu) –
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
例如,要查找每個產(chǎn)品系列中的產(chǎn)品數(shù)量,可以使用 COUNT 函數(shù)與 GROUP BY 子句,如下查詢所示:
SELECT productline, count(*) FROM products GROUP BY productline;
執(zhí)行上面代碼,得到以下結(jié)果 –
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
要查找供應(yīng)商提供的產(chǎn)品數(shù)量,請使用以下查詢:
SELECT productvendor, count(*) FROM products GROUP BY productvendor;
執(zhí)行上面代碼,得到以下結(jié)果 –
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
要查找哪個供應(yīng)商提供至少 9 個產(chǎn)品,您可以使用 HAVING 子句在 COUNT 函數(shù)中,如以下查詢語句所示:
SELECT productvendor, count(*) FROM products GROUP BY productvendor
HAVING count(*) = 9;
執(zhí)行上面代碼,得到以下結(jié)果 –
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 函數(shù)中的控制流程功能,例如 IF,IFNULL,CASE 等來計數(shù)其值與條件匹配的行。
例如,以下查詢可以查找有多少被取消,暫停和有爭議的訂單:
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;
執(zhí)行上面代碼,得到以下結(jié)果 –
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
如果訂單的狀態(tài)被取消,保留或有爭議,IF 函數(shù)將返回 1,否則返回 NULL。COUNT 函數(shù)只計數(shù) 1,而不是 NULL 值,因此查詢根據(jù)相應(yīng)的狀態(tài)返回訂單數(shù)。
以上是“mysql 如何查詢并統(tǒng)計數(shù)量”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注丸趣 TV 行業(yè)資訊頻道!