与“WITH ROLLUP”修饰符一起在 GROUP BY 列表中使用显式排序顺序(ASC 或 DESC)时,会对摘要输出产生什么影响?
在使用“WITH ROLLUP”修饰符在 GROUP BY 列表中使用显式排序顺序(ASC 或 DESC)时,ROLLUP 添加的摘要行仍然会出现在计算它们的行的后面,而不管排序顺序如何。
如我们所知,默认排序顺序是升序,因此在下面的示例中,如果我们不使用任何显式排序顺序,那么输出将如下所示 −
mysql> Select sr, SUM(Price) AS Price from ratelist Group by sr with rollup; +-----+-------+ | sr | Price | +-----+-------+ | 1 | 502 | | 2 | 630 | | 3 | 1005 | | 4 | 850 | | 5 | 250 | |NULL | 3237 | +-----+-------+ 6 rows in set (0.00 sec)
现在,在将排序顺序定义为 DESC 之后,我们将从上面相同的查询中获得以下输出 −
mysql> Select sr, SUM(Price) AS Price from ratelist Group by sr DESC with rollup; +-----+-------+ | sr | Price | +-----+-------+ | 5 | 250 | | 4 | 850 | | 3 | 1005 | | 2 | 630 | | 1 | 502 | |NULL | 3237 | +-----+-------+ 6 rows in set (0.00 sec)
可以从输出中观察到,尽管排序顺序已更改为降序,但摘要行仍出现在计算它们的行的后面。
广告