好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > SQLServer 數(shù)據(jù)庫的數(shù)據(jù)匯總完全解析(WITH ROLLUP)

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

熱門標(biāo)簽:百度地圖標(biāo)注改顏色 貴州房產(chǎn)智能外呼系統(tǒng)供應(yīng)商 鎮(zhèn)江網(wǎng)路外呼系統(tǒng)供應(yīng)商 申請400電話在哪辦理流程 一個導(dǎo)航軟件能用幾個地圖標(biāo)注點 臨沂智能電銷機器人加盟哪家好 外呼運營商線路收費 小e電話機器人 電銷外呼有錄音系統(tǒng)有哪些

現(xiàn)有表A,內(nèi)容如下:

編碼  倉庫  數(shù)量
      01   A    6
      01   B    7
      02   A    8
      02   B    9

現(xiàn)在想按編碼查詢出這種格式:

01   A    6
      01   B    7
      匯總小計:   13
      02   A    8
      02   B    9
      匯總小計:   17

問:該如何實現(xiàn)?

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

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

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

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

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

CUBE 和 ROLLUP 之間的區(qū)別在于:

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

ROLLUP 生成的結(jié)果集顯示了所選列中值的某一層次結(jié)構(gòu)的聚合。

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

SELECT 編碼, 倉庫, Sum(數(shù)量) as 數(shù)量
      FROM A
      GROUP BY 編碼, 倉庫 WITH ROLLUP

--關(guān)鍵就是后面的WITH ROLLUP

--當(dāng)然,你也可以用WITH CUBE,但是結(jié)果會有點不大一樣

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

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

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

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

編碼    倉庫    數(shù)量
      01      A      6
      01      B      7
      01     NULL     13
      02      A      8
      02      B      9
      02     NULL     17
      NULL    NULL     30

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

NULL     A     14
      NULL     B     16

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

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

NULL NULL 30是對所有資料行數(shù)量的匯總。

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

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(數(shù)量) AS 數(shù)量
      FROM A
      GROUP BY 編碼, 倉庫 WITH ROLLUP

--適當(dāng)?shù)倪\用Case函數(shù)

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

2、利用程序做進一步的優(yōu)化

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

WHILE(未到達最后一條記錄){
        IF 編碼值不為ALL而倉庫值為ALL
        {
           將編碼值用“小計:”替換,將倉庫值用""替換;
           將這一行的顏色標(biāo)示為灰色;
        }
        ELSE 編碼值為ALL倉庫值也為ALL
        {
           將編碼值用“總計:”替換,將倉庫值用""替換;
           將這一行的著色標(biāo)示為淡綠色;
        }
        指針移到下一條;
      }
您可能感興趣的文章:
  • SQLServer中匯總功能的使用GROUPING,ROLLUP和CUBE
  • SQL Server優(yōu)化50法匯總
  • SQL Server頁類型匯總+疑問匯總
  • SQLServer與Oracle常用函數(shù)實例對比匯總
  • SQL Server數(shù)據(jù)匯總五招輕松搞定

標(biāo)簽:合肥 日照 嘉興 晉城 三明 延邊 澳門 保定

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQLServer 數(shù)據(jù)庫的數(shù)據(jù)匯總完全解析(WITH ROLLUP)》,本文關(guān)鍵詞  SQLServer,數(shù)據(jù)庫,的,數(shù)據(jù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQLServer 數(shù)據(jù)庫的數(shù)據(jù)匯總完全解析(WITH ROLLUP)》相關(guān)的同類信息!
  • 本頁收集關(guān)于SQLServer 數(shù)據(jù)庫的數(shù)據(jù)匯總完全解析(WITH ROLLUP)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章

    上一篇:通過SQL語句直接把表導(dǎo)出為XML格式

    下一篇:sqlserver Union和SQL Union All使用方法

    主站蜘蛛池模板: 两个人看的www免费高清| 丝袜香蕉一道丝袜国产AV| 超级黄色电影| 51丨国产丨白浆秘?| 娇喘视频网站| 91久久精品一二三产国品色少妇| 91精品人妻一区二区三区蜜桃臀| 美女被狂揉下部?羞羞作文| 97在线视频精品| 成人欧美一区二区三区白人| 三个黑人巨大三根一起进| 皇上好涨奴婢夹不文H| 韩国19?vip韩宝贝在线| 国产乱论视频| 国产精品秘?入口福利| 亚洲天堂网在线观看视频 | 九龙坡区| 50岁丰满女人下面毛耸耸| 无限资源免费观看在线完整版| 公车挺进尤物少妇翘臀视频| 大逼逼aⅴ| 免费看黄色网址| 久久99精品国产麻豆| 女人呻吟双腿大开男女H漫画 | 国产??在线观看免费视频| 色欲av蜜臀av久久浪潮av| 欧美日韩高清国产精品一区二区| 20|9伦理片| 男gaygays小鲜肉按摩| 丁香六月在线| 免费国产一级??片????,,,| 美女用手扒开尿口给男生桶爽| freex性hd| 亚洲午夜国产精品| 高h道具调教甜宠各种play| 久久这里只有精品国产精品99| 欧美一级看片a免费观看| 不要h| 日韩在线三级| 四虎视频国产精品免费 | 欧美特级黄色片|