現(xiàn)有表Test,內(nèi)容如下: ID Catalog Num 1 A 3 1 B 52 A 8 2 B 2 現(xiàn)在想按ID查詢出這種結(jié)果: -------------------- 1 A 31 B 5 匯總小計(jì): 82 A 8 2 B 2 匯總小計(jì): 10 問(wèn):該如何實(shí)現(xiàn)?
在生成包含小計(jì)和合計(jì)的報(bào)表時(shí),ROLLUP 運(yùn)算符很有用。ROLLUP 運(yùn)算符生成的結(jié)果集類似于 CUBE 運(yùn)算符所生成的結(jié)果集。 ======================== CUBE 運(yùn)算符生成的結(jié)果集是多維數(shù)據(jù)集。多維數(shù)據(jù)集是事實(shí)數(shù)據(jù)的擴(kuò)展,事實(shí)數(shù)據(jù)即記錄個(gè)別事件的數(shù)據(jù)。擴(kuò)展建立在用戶打算分析的列上。這些列被稱為維。多維數(shù)據(jù)集是一個(gè)結(jié)果集,其中包含了各維度的所有可能組合的交叉表格。 CUBE 運(yùn)算符在 SELECT 語(yǔ)句的 GROUP BY 子句中指定。該語(yǔ)句的選擇列表應(yīng)包含維度列和聚合函數(shù)表達(dá)式。GROUP BY 應(yīng)指定維度列和關(guān)鍵字 WITH CUBE。結(jié)果集將包含維度列中各值的所有可能組合,以及與這些維度值組合相匹配的基礎(chǔ)行中的聚合值。 ========================= CUBE 和 ROLLUP 之間的區(qū)別在于: CUBE 生成的結(jié)果集顯示了所選列中值的所有組合的聚合。 ROLLUP 生成的結(jié)果集顯示了所選列中值的某一層次結(jié)構(gòu)的聚合。
The ROLLUP operator is useful in generating reports that contain subtotals and totals. The ROLLUP operator generates a result set that is similar to the result sets generated by the CUBE operator.
The differences between CUBE and ROLLUP are:
CUBE generates a result set showing aggregates for all combinations of values in the selected columns.ROLLUP generates a result set showing aggregates for a hierarchy of values in the selected columns.
最后查詢語(yǔ)句如下:
SELECT CASE WHEN (GROUPING(ID) = 1) THEN @#ALL@# ELSE ISNULL(ID, @#UNKNOWN@#) END AS ID, CASE WHEN (GROUPING(Catalog) = 1) THEN @#ALL@# ELSE ISNULL(Catalog, @#UNKNOWN@#) END AS Catalog, SUM(Num) AS Num FROM Test GROUP BY ID, Catalog WITH ROLLUP
在生成包含小計(jì)和合計(jì)的報(bào)表時(shí),ROLLUP 運(yùn)算符很有用。ROLLUP 運(yùn)算符生成的結(jié)果集類似于 CUBE 運(yùn)算符所生成的結(jié)果集。 ======================== CUBE 運(yùn)算符生成的結(jié)果集是多維數(shù)據(jù)集。多維數(shù)據(jù)集是事實(shí)數(shù)據(jù)的擴(kuò)展,事實(shí)數(shù)據(jù)即記錄個(gè)別事件的數(shù)據(jù)。擴(kuò)展建立在用戶打算分析的列上。這些列被稱為維。多維數(shù)據(jù)集是一個(gè)結(jié)果集,其中包含了各維度的所有可能組合的交叉表格。 CUBE 運(yùn)算符在 SELECT 語(yǔ)句的 GROUP BY 子句中指定。該語(yǔ)句的選擇列表應(yīng)包含維度列和聚合函數(shù)表達(dá)式。GROUP BY 應(yīng)指定維度列和關(guān)鍵字 WITH CUBE。結(jié)果集將包含維度列中各值的所有可能組合,以及與這些維度值組合相匹配的基礎(chǔ)行中的聚合值。 ========================= CUBE 和 ROLLUP 之間的區(qū)別在于: CUBE 生成的結(jié)果集顯示了所選列中值的所有組合的聚合。 ROLLUP 生成的結(jié)果集顯示了所選列中值的某一層次結(jié)構(gòu)的聚合。
The ROLLUP operator is useful in generating reports that contain subtotals and totals. The ROLLUP operator generates a result set that is similar to the result sets generated by the CUBE operator.
The differences between CUBE and ROLLUP are:
CUBE generates a result set showing aggregates for all combinations of values in the selected columns.ROLLUP generates a result set showing aggregates for a hierarchy of values in the selected columns.
最后查詢語(yǔ)句如下:
SELECT CASE WHEN (GROUPING(ID) = 1) THEN @#ALL@# ELSE ISNULL(ID, @#UNKNOWN@#) END AS ID, CASE WHEN (GROUPING(Catalog) = 1) THEN @#ALL@# ELSE ISNULL(Catalog, @#UNKNOWN@#) END AS Catalog, SUM(Num) AS Num FROM Test GROUP BY ID, Catalog WITH ROLLUP