亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

SQLServer 數據庫的數據匯總完全解析(WITH ROLLUP)

2024-08-31 00:58:32
字體:
來源:轉載
供稿:網友

現有表A,內容如下:

編碼 倉庫 數量01 A 601 B 702 A 802 B 9

現在想按編碼查詢出這種格式:

01 A 601 B 7匯總小計: 1302 A 802 B 9匯總小計: 17

問:該如何實現?

乍一看,好像很容易,用group by好像能實現?但仔細研究下去,你又會覺得group by也是無能為力,總欠缺點什么,無從下手。那么,到底該如何做呢?別急,SQL Server早就幫我們做好了,下面,跟我來。

首先,讓我們來看一段話:

在生成包含小計和合計的報表時,ROLLUP 運算符很有用。ROLLUP 運算符生成的結果集類似于 CUBE 運算符所生成的結果集。

CUBE 運算符生成的結果集是多維數據集。多維數據集是事實數據的擴展,事實數據即記錄個別事件的數據。擴展建立在用戶打算分析的列上。這些列被稱為維。多維數據集是一個結果集,其中包含了各維度的所有可能組合的交叉表格。

CUBE 運算符在 SELECT 語句的 GROUP BY 子句中指定。該語句的選擇列表應包含維度列和聚合函數表達式。GROUP BY 應指定維度列和關鍵字 WITH CUBE。結果集將包含維度列中各值的所有可能組合,以及與這些維度值組合相匹配的基礎行中的聚合值。

CUBE 和 ROLLUP 之間的區別在于:

CUBE 生成的結果集顯示了所選列中值的所有組合的聚合。

ROLLUP 生成的結果集顯示了所選列中值的某一層次結構的聚合。

看完以上的這段話,悟出了什么沒有?如果沒有,那么……嘿嘿,你的悟性還不夠喲,離“三花棸頂”還早著呢:)。接下來我們再看一段(注意喲,答案馬上就揭曉了):

SELECT 編碼, 倉庫, Sum(數量) as 數量FROM AGROUP BY 編碼, 倉庫 WITH ROLLUP

--關鍵就是后面的WITH ROLLUP

--當然,你也可以用WITH CUBE,但是結果會有點不大一樣

可能看完上面這段你還是覺得“云里霧里”,摸不著頭腦。實在不明白也沒關系,自己動手做。

首先:建一個上面所說的A表,輸入幾行數據;

接著:打開你的SQL Server查詢分析器,連上包含你上面所建A表的服務器,選擇包含該表的數據庫;

然后:Copy上面這段SQL 語句,Paste到查詢分析器中,按F5,怎么樣?看到下面出來了什么?是不是和我下面的一樣?

編碼 倉庫 數量01A 601B   701   NULL  1302A802B902   NULL   17NULL NULL   30

--如果你用的是WITH CUBE,結果集的后面還會多出兩條(如果你也只是輸入示例中的幾行數據的話):

NULLA14NULLB16

咦!奇怪,結果中怎么有那么多“NULL”值?哈,別急,這幾行正是我們所要的匯總數據行,不難看出:

01 NULL 13正是對編碼為01的所有倉庫中的數量的匯總;02 NULL 17是對編碼為02的所有倉庫的數量的匯總;

NULL NULL 30是對所有資料行數量的匯總。

如何?答案出來了吧?是不是很簡單呢?當然,上面還有點美中不足,那就是有好多“NULL”的存在。如何去掉這些無意義的NULL呢?下面我們再進行優化。

1、用Grouping替換NULL值

SELECT CASE WHEN (GROUPING(編碼) = 1) THEN 'ALL'ELSE ISNULL(編碼, 'UNKNOWN')END AS 編碼,CASE WHEN (GROUPING(倉庫) = 1) THEN 'ALL'ELSE ISNULL(倉庫, 'UNKNOWN')END AS 倉庫,SUM(數量) AS 數量FROM AGROUP BY 編碼, 倉庫 WITH ROLLUP

--適當的運用Case函數

結果我這里就不寫了,就是把上面的“NULL”值全部換成“ALL”字符串

2、利用程序做進一步的優化

//通常為了顯示上的需要,我們必須對以上SQL語句生成的結果做一些優化,下面給出自然語言描述:

WHILE(未到達最后一條記錄){  IF 編碼值不為ALL而倉庫值為ALL ?。    ⒕幋a值用“小計:”替換,將倉庫值用""替換;     將這一行的顏色標示為灰色;  }  ELSE 編碼值為ALL倉庫值也為ALL ?。    ⒕幋a值用“總計:”替換,將倉庫值用""替換;     將這一行的著色標示為淡綠色; ?。 ≈羔樢频较乱粭l;}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久精品一区| 亚洲精品国产精品自产a区红杏吧| 精品视频一区在线视频| 亚洲日韩欧美视频| 国产深夜精品福利| 中文字幕免费精品一区| 成人写真视频福利网| 久久久精品一区| 国产脚交av在线一区二区| 日韩在线观看免费全集电视剧网站| 亚洲欧洲日产国产网站| 夜夜狂射影院欧美极品| 欧美夫妻性生活视频| 久久精品中文字幕免费mv| 在线播放国产精品| 欧美日韩在线另类| 亚洲伦理中文字幕| 欧美插天视频在线播放| 一本色道久久综合狠狠躁篇的优点| 九九九久久久久久| 一区二区三区黄色| 91免费视频网站| 欧美有码在线视频| 97视频国产在线| 91香蕉嫩草神马影院在线观看| 日本久久久久久久| 精品久久久久久| 国产日韩在线一区| 亚洲美女动态图120秒| 亚洲欧美日韩中文在线| 亚洲乱码国产乱码精品精| 91成人天堂久久成人| 91国偷自产一区二区三区的观看方式| 国产成人小视频在线观看| 欧美一级成年大片在线观看| 亚洲国产精品系列| 欧美夫妻性视频| 欧美裸体男粗大视频在线观看| 欧美黄色片在线观看| 久久久久久12| 亚洲free嫩bbb| 成人精品一区二区三区电影免费| 国产日韩精品综合网站| 国产福利视频一区二区| 欧美一区二区三区精品电影| 色先锋资源久久综合5566| 久久久久久久久久久人体| 国产一区二区三区日韩欧美| 亚洲第五色综合网| 日韩精品久久久久久福利| 亚洲男人天堂古典| 91wwwcom在线观看| 欧美激情手机在线视频| 亚洲免费影视第一页| 国产精欧美一区二区三区| 成人夜晚看av| 国产综合色香蕉精品| 91香蕉电影院| 国产亚洲精品美女久久久| 日韩高清电影免费观看完整版| 国产欧美精品日韩| 国产福利精品视频| 欧美不卡视频一区发布| 国产精品高潮呻吟久久av野狼| 欧美美女18p| 91美女高潮出水| 在线日韩第一页| 国产日本欧美一区| 在线观看国产精品淫| 成人免费在线网址| 欧美成人免费观看| 亚洲人成网站999久久久综合| 国内精品久久久久影院 日本资源| 久久久视频精品| 亚洲精品久久久久久下一站| 中文字幕精品一区久久久久| 日韩av在线不卡| 亚洲欧洲日韩国产| www.xxxx精品| zzijzzij亚洲日本成熟少妇| 深夜精品寂寞黄网站在线观看| 日韩在线国产精品| 日韩av大片免费看| 亚洲欧美国产精品专区久久| 成人激情视频小说免费下载| 日韩精品在线免费| 动漫精品一区二区| 日韩av在线网址| 欧美激情亚洲精品| 国产成人精品优优av| 亚洲嫩模很污视频| 久久免费在线观看| 亚洲一二在线观看| 欧美大尺度电影在线观看| 国产美女高潮久久白浆| 欧美日韩在线影院| 国产精品偷伦免费视频观看的| 国产精品国产三级国产aⅴ浪潮| 精品视频在线播放色网色视频| 中文字幕欧美视频在线| 亚洲精品一二区| 性欧美xxxx| 美女少妇精品视频| 欧美性猛交xxxxx免费看| 欧美性猛xxx| 全色精品综合影院| 欧美电影《睫毛膏》| 欧美大片免费观看在线观看网站推荐| 在线观看日韩www视频免费| 国产精品视频免费观看www| 久久久久国产精品www| 97超级碰碰碰| 欧美日产国产成人免费图片| 在线看日韩av| 国产一区二区欧美日韩| 国产69精品久久久久9999| 国产午夜精品麻豆| 欧美日韩国产色视频| 亚洲欧美视频在线| 欧美一区二区三区图| 亚洲综合中文字幕在线| 在线播放精品一区二区三区| 日韩福利视频在线观看| 亚洲天堂av在线免费| 国内外成人免费激情在线视频| 欧美成人中文字幕在线| 色先锋资源久久综合5566| 日韩成人在线视频观看| 国产亚洲精品久久久| 亚洲va久久久噜噜噜久久天堂| 久久久人成影片一区二区三区观看| 亚洲国产成人91精品| 欧美色视频日本高清在线观看| 国产一区二区香蕉| 国产高清在线不卡| 精品亚洲一区二区三区| 亚洲黄页网在线观看| 成人免费xxxxx在线观看| 综合国产在线观看| 欧美精品www在线观看| 久久久久久久久久婷婷| 久久精品中文字幕| 日韩激情视频在线播放| 欧美日韩中文字幕在线视频| 91沈先生在线观看| 91po在线观看91精品国产性色| 日韩欧美国产黄色| 日韩亚洲欧美中文在线| 美日韩精品视频免费看| 国产精品扒开腿做爽爽爽的视频| 亚洲精品第一页| 欧美视频专区一二在线观看| 国产精品成人一区二区| 国产精品久久久久福利| 欧洲永久精品大片ww免费漫画| 亚洲欧美日韩国产中文| 亚洲图片制服诱惑| 久久久中精品2020中文| 久久99久久99精品免观看粉嫩| 国产91精品黑色丝袜高跟鞋| 97av视频在线| 久久精品国产亚洲| 亚洲欧美日韩另类| 欧美放荡办公室videos4k|