久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

mysql如何查詢并統(tǒng)計數(shù)量

141次閱讀
沒有評論

共計 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è)資訊頻道!

正文完
 
丸趣
版權(quán)聲明:本站原創(chuàng)文章,由 丸趣 2023-07-18發(fā)表,共計5374字。
轉(zhuǎn)載說明:除特殊說明外本站除技術(shù)相關(guān)以外文章皆由網(wǎng)絡(luò)搜集發(fā)布,轉(zhuǎn)載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 海口市| 成都市| 侯马市| 琼中| 库尔勒市| 历史| 富川| 阿巴嘎旗| 姜堰市| 聂拉木县| 通海县| 如东县| 林口县| 芦山县| 海城市| 衡山县| 佛教| 克什克腾旗| 黄龙县| 辽宁省| 崇明县| 道孚县| 镇巴县| 阿合奇县| 霍城县| 阿巴嘎旗| 门源| 拜泉县| 通榆县| 黄浦区| 鹿泉市| 九寨沟县| 无为县| 涞源县| 葵青区| 安化县| 淳安县| 苗栗市| 紫金县| 沧州市| 绩溪县|