在使用 ROLLUP 修飾符時,是否可以使用 MySQL 的 ORDER BY 子句對結果進行排序?


實際上,ROLLUP 和 ORDER BY 在 MySQL 中是互斥的,因此在查詢中同時使用它們並不是一個好習慣。但是,如果我們在 ORDER BY 中使用 ROLLUP,那麼主要缺點是彙總行將與它們計算的行一起排序。還需要注意的是,排序順序將決定彙總行的位置。

彙總行將位於升序的開頭和降序的結尾。請考慮以下示例以更清楚地瞭解它 -

mysql> Select * from (Select sr, SUM(PRICE) AS PRICE from ratelist GROUP BY sr WITH ROLLUP) AS Price ORDER BY Sr DESC;
+------+-------+
| sr   | PRICE |
+------+-------+
|    5 |   250 |
|    4 |   850 |
|    3 |  1005 |
|    2 |   630 |
|    1 |   502 |
| NULL |  3237 |
+------+-------+
6 rows in set (0.00 sec)

mysql> Select * from (Select sr, SUM(PRICE) AS PRICE from ratelist GROUP BY sr WITH ROLLUP) AS Price ORDER BY Sr ASC;
+------+-------+
| sr   | PRICE |
+------+-------+
| NULL |  3237 |
|    1 |   502 |
|    2 |   630 |
|    3 |  1005 |
|    4 |   850 |
|    5 |   250 |
+------+-------+
6 rows in set (0.01 sec)

更新於: 2020年6月22日

337 次檢視

啟動你的 職業生涯

透過完成課程獲得認證

立即開始
廣告

© . All rights reserved.