MySQL是一種流行的關系型數據庫管理系統,它支持在查詢中同時使用分組和不分組的方法來篩選數據。
在不分組的情況下,查詢的結果是整張表或表中一個符合條件的記錄列表。它只使用WHERE子句作為條件篩選器,不使用GROUP BY子句對數據進行聚合。例如:
SELECT customer_name, order_date, order_total FROM orders WHERE order_date >= '2020-01-01' ORDER BY order_total DESC;
這個查詢將返回在2020年1月1日之后下單的所有訂單,按訂單總額從高到低排序。
但是,如果我們想得到每個客戶的平均訂單總額,我們需要使用GROUP BY子句將結果分組:
SELECT customer_name, AVG(order_total) as avg_total FROM orders WHERE order_date >= '2020-01-01' GROUP BY customer_name ORDER BY avg_total DESC;
這個查詢將返回每個客戶的平均訂單總額,并將它們按平均總額從高到低排序。
然而,如果我們還想得到每個客戶在2020年下單的詳細信息,可以使用子查詢:
SELECT customer_name, order_date, order_total, avg_total FROM orders JOIN (SELECT customer_name, AVG(order_total) as avg_total FROM orders WHERE order_date >= '2020-01-01' GROUP BY customer_name) as avg_orders ON orders.customer_name = avg_orders.customer_name WHERE order_date >= '2020-01-01' ORDER BY avg_total DESC, order_total DESC;
這個查詢將連接訂單表和平均訂單總額表,得到每個客戶在2020年下單的詳細信息,并按平均總額和訂單總額從高到低排序。