當(dāng)前位置:首頁 > IT技術(shù) > 數(shù)據(jù)庫 > 正文

MySql聚集函數(shù)
2021-10-07 11:29:49

聚集函數(shù)(aggregate function) 運(yùn)行在行組上,計算和返回單個值的函數(shù)

AVG

# 計算供應(yīng)商為1003的所有商品的平均值
SELECT AVG(prod_price) AS avg_price
FROM products
WHERE vend_id = 1003;

COUNT

COUNT()函數(shù)有兩種使用方式。

  1. 使用COUNT(*)對表中行的數(shù)目進(jìn)行計數(shù),不管表列中包含的是空值(NULL)還是非空值。
  2. 使用 COUNT(column) 對特定列中具有值的行進(jìn)行計數(shù), 忽略NULL值。
# 計算擁有email信息的顧客的數(shù)量
SELECT COUNT(cust_email) AS num_cust
FROM customers;

# 計算customers表中客戶的總數(shù)
SELECT COUNT(*) AS num_cust
FROM customers;

MAX

# 計算商品表中最貴的商品價格
SELECT MAX(prod_price) AS max_price
FROM products;

注意:雖然 MAX() 一般用來找出最大的數(shù)值或日期值,但MySQL允許將它用來返回任意列中的最大值,包括返回文本列中的最大值。在用于文本數(shù)據(jù)時,如果數(shù)據(jù)按相應(yīng)的列排序,則MAX()返回最后一行

MIN

# 計算商品表中最便宜的商品價格
SELECT MIN(prod_price) AS max_price
FROM products;

注意:MIN() 函數(shù)與 MAX() 函數(shù)類似,MySQL允許將它用來返回任意列中的最小值,包括返回文本列中的最小值。在用于文本數(shù)據(jù)時,如果數(shù)據(jù)按相應(yīng)的列排序,則MIN()返回最前面的行

SUM

下面舉一個例子,orderitems表包含訂單中實際的物品,每個物品有相應(yīng)的數(shù)量( quantity )。 可如下檢索所訂購物品的總數(shù)(所有 quantity值之和)

SELECT SUM(quantity) AS items_ordered
FROM orderitems
WHERE order_num = 20005;

聚合組合函數(shù)

聚合組合函數(shù),實際上SELECT 語句可根據(jù)需要包含多個聚集函數(shù)

# 
SELECT COUNT(*) AS num_items,
MIN(prod_price) AS min_price
MAX(prod_price) AS max_price
AVG(prod_price) AS avg_price
FROM products;

注意:在指定別名以包含某個聚集函數(shù)的結(jié)果時,不應(yīng)該使用表中實際的列名。雖然這樣做并非不合法,但使用唯一的名字(別名)會使你的SQL更易于理解和使用

本文摘自 :https://www.cnblogs.com/

開通會員,享受整站包年服務(wù)立即開通 >