600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > MYSQL数据分组(十三)GROUP BY

MYSQL数据分组(十三)GROUP BY

时间:2020-05-15 05:08:35

相关推荐

MYSQL数据分组(十三)GROUP BY

MySQL GROUP BY子句

GROUP BY子句是SELECT语句的可选部分,它将一组行记录按列或表达式的值分组成摘要行记录。GROUP BY子句返回每个分组的一个行记录。换句话说,它减少了在结果集中的行数。

我们经常使用GROUP BY子句在聚合函数中使用,如:SUM,AVG,MAX,MIN, 和COUNT。聚合函数出现在SELECT子句中并提供有关每分组的信息。

以下说明了GROUP BY子句的语法:

SELECT c1, c2,..., cn, aggregate_function(ci)FROMtableWHEREwhere_conditionsGROUP BY c1 , c2,...,cn;

GROUP BY子句必须在FROM和WHERE子句后出现。 在GROUP BY关键字之后要使用逗号分隔列或表达式列表作为标准分组行。

MySQL GROUP BY示例

让我们来看看示例数据库中的orders表。

假设我们要使用order表中的status字段作为分组字段,使用GROUP BY子句的status列如下面的查询所示:

SELECT statusFROMordersGROUP BY status;

结果如下:

我们可以看到,GROUP BY子句返回status值的唯一匹配项。它的工作原理类似下面显示的DISTINCT运算符查询:

SELECT DISTINCTstatusFROMorders;

MySQL GROUP BY与聚合函数

聚合函数允许我们执行某组行的计算并返回一个值。GROUP BY子句通常与聚合函数来执行计算,并为每个分组返回一个值。

例如,如果我们想知道每一种状态有多少个订单,可以使用COUNT函数与GROUP BY子句如下:

SELECT status, COUNT(*)FROMordersGROUP BY status;

结果如下:

见下表ordersorderdetails表。

要通过订单状态查询所有订单的总金额,这里order表需要连接order_detail表,并使用SUM函数来计算总额。请参考下面的查询:

SELECT status, SUM(quantityOrdered * priceEach) AS amountFROMordersINNER JOINorderdetails USING (orderNumber)GROUP BY status;

结果如下:

下面的查询返回订单号和每个订单的总额。

SELECT orderNumber,SUM(quantityOrdered * priceEach) AS totalFROMorderdetailsGROUP BY orderNumber;

结果如下:

MySQL GROUP BY与表达式示例

除了列,我们可以通过表达式来进行分组行。下面的查询获取每月的销售总额。我们使用YEAR函数从订单日期(order_date字段)中提取年份信息。我们只查询发货状态是完成的订单。请注意,该表达式出现在SELECT子句中必须与在GROUP BY子句中一样。

SELECT YEAR(orderDate) AS year,SUM(quantityOrdered * priceEach) AS totalFROMordersINNER JOINorderdetails USING (orderNumber)WHEREstatus = 'Shipped'GROUP BY YEAR(orderDate);

结果如下:

MySQL GROUP BY与HAVING

要筛选由GROUP BY子句返回分组行,我们使用HAVING子句。下面是使用HAVING子句查询之后的年份的总销售额。

SELECT YEAR(orderDate) AS year,SUM(quantityOrdered * priceEach) AS totalFROMordersINNER JOINorderdetails USING (orderNumber)WHEREstatus = 'Shipped'GROUP BY yearHAVING year > ;

结果如下:

MySQL和标准SQL中的GROUP BY子句

标准SQL不允许我们在GROUP BY子句中使用别名,但MySQL支持这一点。下面的查询语句是从订单日期提取年份并计算每年的订单数量。year被使用作为表达式YEAR(orderDate)的别名。我们用year这个别名在GROUP BY子句中。但是这样的用法在查询标准SQL中是非法的。

SELECT YEAR(orderDate) AS year, COUNT(orderNumber)FROMordersGROUP BY year;

结果如下:

MySQL也允许我们按升序或降序对分组的订单行记录进行排序,而标准SQL是不可以的,它默认顺序是升序。例如,如果我们想要查询每种订单状态的订单数量并按订单状态(status字段)降序排列,可以使用GROUP BY子句及DESC,如下查询:

SELECT status, COUNT(*)FROMordersGROUP BY status DESC;

结果如下:

注意,我们使用DESC在GROUP BY子句之后,来按订单状态(status字段)进行降序排序。我们可以在GROUP BY子句之后明确指定使用 ASC 来按订单状态(status字段)升序排序。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。