1. 程式人生 > 資料庫 >詳解MySQL 資料分組

詳解MySQL 資料分組

建立分組

分組是在SELECT語句中的GROUP BY 子句中建立的。

例:

SELECT vend_id,COUNT(*) AS num_prods FROM products GROUP BY vend_id;

詳解MySQL 資料分組

GROUP BY

  • GROUP BY子句可以包含任意數目的列,這使得能對分組進行巢狀,為資料分組提供更細緻的控制。
  • 如果在GROUP BY子句中嵌套了分組,資料將在最後規定的分組商家進行彙總。換句話說,在建立分組時,指定的所有列都一起計算。(所有不能從個別的列取回資料)。
  • GROUP BY子句中列出的每個列都必須是檢索列或有效的表示式(但不能是聚集函式)。如果在SELECT中使用表示式,則必須在GROUP BY子句中指定相同的表示式,不能使用別名
  • 除聚集計算語句外,SELECT語句中的每個列都必須在GROUP BY子句中給出。
  • 如果分組列中具有NULL值,則NULL將作為一個分組返回。如果列中有多行NULL值,他們將分為一組。
  • GROUP BY子句必須出現在WHERE子句之後,ORDER BY 子句之前。

過濾分組

如果想要列出至少有兩個訂單的所有骨科,這樣的資料就必須基於完整的分組而不是個別的行進行過濾。

可以使用HAVING

SELECT cust_id,COUNT(*) AS orders FROM orders GROUP BY cust_id HAVING COUNT(*) >= 2;

詳解MySQL 資料分組

HAVING和WHERE的差別,WHERE在資料分組前進行過濾,HAVING在分組後進行過濾。當然,兩個也可以在同一條語句中出現。

列出具有2個(含)以上、價格為10(含)以上的產品的供應商

SELECT vend_id,COUNT(*) AS num_prods FROM products WHERE prod_price >= 10 GROUP BY vend_id HAVING COUNT(*) >= 2;

詳解MySQL 資料分組

列出具有兩個至上的產品的供應商

SELECT vend_id,COUNT(*) AS num_prods FROM products GROUP BY vend_id HAVING COUNT(*) >= 2;

詳解MySQL 資料分組

分組和排序

ORDER BY GROUP BY
排序產生的輸出 分組行。但輸出可能不是分組的順序
任意列都可以使用(非選擇的列也可以) 只可能使用選擇列或表示式列,而且必須使用每個選擇列表達式
不一定需要 如果與聚集函式一起使用列(表示式),則必須使用

檢索總計訂單價格大於等於50的訂單的訂到號和總計訂單價格

SELECT order_num,SUM(quantity*item) AS ordertotal FROM orderitems GROUP BY order_num HAVING SUM(quantity*item_price) >= 50;

詳解MySQL 資料分組

如果按總計訂單價格排序輸出

SELECT order_num,SUM(quantity * item_price) AS ordertotal FROM orderitems GROUP BY order_num HAVING SUM(quantity * item_price) >= 50 ORDER BY ordertotal;

詳解MySQL 資料分組

SELECT子句的順序

子句 說明 是否必須使用
SELECT 要返回的列或表示式
FROM 從中檢索資料的表 僅在從表選擇資料時使用
GROUP BY 分組說明 僅在按組計算聚集時使用
WHERE 行級過濾
HAVING 組級過濾
ORDER BY 輸出排序順序
LIMIT 要檢索的行數

以上就是詳解MySQL 資料分組的詳細內容,更多關於MySQL資料分組的資料請關注我們其它相關文章!