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

mysql如何查詢并統計數量

135次閱讀
沒有評論

共計 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字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 阿荣旗| 阳山县| 江津市| 阿克陶县| 铜陵市| 元江| 孟连| 抚远县| 旌德县| 尉氏县| 青田县| 扎鲁特旗| 奈曼旗| 长宁区| 福泉市| 柘荣县| 准格尔旗| 鄂州市| 海城市| 贵州省| 崇州市| 康保县| 通山县| 泸西县| 唐海县| 九台市| 苍山县| 永顺县| 湄潭县| 平罗县| 唐海县| 黄陵县| 留坝县| 华容县| 麻城市| 虹口区| 德昌县| 武山县| 普宁市| 阿尔山市| 鄯善县|