sqlserver——cube:多維數據集

来源:http://www.cnblogs.com/liujianshe1990-/archive/2017/07/28/7249406.html
-Advertisement-
Play Games

1、cube:生成多維數據集,包含各維度可能組合的交叉表格,使用with 關鍵字連接 with cube 根據需要使用union all 拼接 判斷 某一列的null值來自源數據還是 cube 使用GROUPING關鍵字 GROUPING([檔案號]) = 1 : null值來自cube(代表所有的 ...


1、cube:生成多維數據集,包含各維度可能組合的交叉表格,使用with 關鍵字連接 with cube

根據需要使用union all 拼接
判斷 某一列的null值來自源數據還是 cube 使用GROUPING關鍵字
GROUPING([檔案號]) = 1 : null值來自cube(代表所有的檔案號)
GROUPING([檔案號]) = 0 : null值來自源數據

 

舉例:

 

  1 SELECT  * INTO ##GET
  3                 FROM
  4                     (
  5                         SELECT
  6                             *
  7                         FROM
  8                             (
  9                                 SELECT
 10                                     CASE
 11                                 WHEN (GROUPING([檔案號]) = 1) THEN
 12                                     '合計'
 13                                 ELSE
 14                                     [檔案號]
 15                                 END AS '檔案號',
 16                                 CASE
 17                             WHEN (GROUPING([系列]) = 1) THEN
 18                                 '合計'
 19                             ELSE
 20                                 [系列]
 21                             END AS '系列',
 22                             CASE
 23                         WHEN (GROUPING([店長]) = 1) THEN
 24                             '合計'
 25                         ELSE
 26                             [店長]
 27                         END AS '店長',
 28                         SUM (剩餘次數) AS '總剩餘',
 29                         CASE
 30                     WHEN (GROUPING([店名]) = 1) THEN
 31                         '合計'
 32                     ELSE
 33                         [店名]
 34                     END AS '店名'
 35                     FROM
 36                         ##PudianCard
 37                     GROUP BY
 38                         [檔案號],
 39                         [店名],
 40                         [店長],
 41                         [系列] WITH cube
 42                     HAVING
 43                         GROUPING([店名]) != 1
 44                     AND GROUPING([檔案號]) = 1 --AND GROUPING([系列]) = 1
 45                             ) AS M
 46                         UNION ALL
 47                             (
 48                                 SELECT
 49                                     *
 50                                 FROM
 51                                     (
 52                                         SELECT
 53                                             CASE
 54                                         WHEN (GROUPING([檔案號]) = 1) THEN
 55                                             '合計'
 56                                         ELSE
 57                                             [檔案號]
 58                                         END AS '檔案號',
 59                                         CASE
 60                                     WHEN (GROUPING([系列]) = 1) THEN
 61                                         '合計'
 62                                     ELSE
 63                                         [系列]
 64                                     END AS '系列',
 65                                     CASE
 66                                 WHEN (GROUPING([店長]) = 1) THEN
 67                                     '合計'
 68                                 ELSE
 69                                     [店長]
 70                                 END AS '店長',
 71                                 SUM (剩餘次數) AS '總剩餘',
 72                                 CASE
 73                             WHEN (GROUPING([店名]) = 1) THEN
 74                                 '合計'
 75                             ELSE
 76                                 [店名]
 77                             END AS '店名'
 78                             FROM
 79                                 ##PudianCard
 80                             GROUP BY
 81                                 [檔案號],
 82                                 [店名],
 83                                 [店長],
 84                                 [系列] WITH cube
 85                             HAVING
 86                                 GROUPING([店名]) != 1
 87                             AND GROUPING([店長]) != 1
 88                                     ) AS P
 89                             )
 90                         UNION ALL
 91                             (
 92                                 SELECT
 93                                     *
 94                                 FROM
 95                                     (
 96                                         SELECT
 97                                             CASE
 98                                         WHEN (GROUPING([檔案號]) = 1) THEN
 99                                             '合計'
100                                         ELSE
101                                             [檔案號]
102                                         END AS '檔案號',
103                                         CASE
104                                     WHEN (GROUPING([系列]) = 1) THEN
105                                         '合計'
106                                     ELSE
107                                         [系列]
108                                     END AS '系列',
109                                     CASE
110                                 WHEN (GROUPING([店長]) = 1) THEN
111                                     '合計'
112                                 ELSE
113                                     [店長]
114                                 END AS '店長',
115                                 SUM (剩餘次數) AS '總剩餘',
116                                 CASE
117                             WHEN (GROUPING([店名]) = 1) THEN
118                                 '合計'
119                             ELSE
120                                 [店名]
121                             END AS '店名'
122                             FROM
123                                 ##PudianCard
124                             GROUP BY
125                                 [檔案號],
126                                 [店名],
127                                 [店長],
128                                 [系列] WITH cube
129                             HAVING
130                                 GROUPING([店名]) != 1
131                             AND GROUPING([店長]) != 1
132                                     ) AS W
133                             )
134                         UNION ALL
135                             (
136                                 SELECT
137                                     *
138                                 FROM
139                                     (
140                                         SELECT
141                                             CASE
142                                         WHEN (GROUPING([檔案號]) = 1) THEN
143                                             '合計'
144                                         ELSE
145                                             [檔案號]
146                                         END AS '檔案號',
147                                         CASE
148                                     WHEN (GROUPING([系列]) = 1) THEN
149                                         '合計'
150                                     ELSE
151                                         [系列]
152                                     END AS '系列',
153                                     CASE
154                                 WHEN (GROUPING([店長]) = 1) THEN
155                                     '合計'
156                                 ELSE
157                                     [店長]
158                                 END AS '店長',
159                                 SUM (剩餘次數) AS '總剩餘',
160                                 CASE
161                             WHEN (GROUPING([店名]) = 1) THEN
162                                 '合計'
163                             ELSE
164                                 [店名]
165                             END AS '店名'
166                             FROM
167                                 ##PudianCard
168                             GROUP BY
169                                 [檔案號],
170                                 [店名],
171                                 [店長],
172                                 [系列] WITH cube
173                             HAVING
174                                 GROUPING([店名]) = 1
175                             AND GROUPING([店長]) = 1
176                             AND GROUPING([檔案號]) = 1
177                                     ) AS K
178                             )
179                     ) AS T
2、rollup:功能跟cube相似

3、將某一列的數據作為列名,動態載入,使用存儲過程,拼接字元串
DECLARE @st nvarchar (MAX) = '';

SELECT
@st =@st + 'max(case when [系列]=''' + CAST ([系列] AS VARCHAR) + ''' then [總剩餘] else null end ) as [' + CAST ([系列] AS VARCHAR) + '],'
FROM
##GET
GROUP BY
[系列];
print @st;

4、根據某一列分組,分別建表
SELECT
'select ROW_NUMBER() over(order by [卡項] desc) as [序號], [會員],[檔案號],[卡項],[剩餘次數],[員工],[店名] into ' + ltrim([店名]) + ' from 查詢 where [店名]=''' + [店名] + ''' ORDER BY [卡項] desc'
FROM
查詢
GROUP BY
[店名]

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 轉自:http://www.maomao365.com/?p=4508 <span style="color:red;font-weight:bold;">我們熟知一個視圖需要滿足以下條件,我們才可以使用upate視圖來通過視圖修改數據的目標,那麼現在有一個需求,領導需要我們建立一個視圖,並且禁止通 ...
  • 在一切開始之前,先看下微軟的建議:在系統的整體性能優化裡面, TSQL優化優先順序並不是最高的。 本文包括四部分: SET STATISTICS TIME ON SET STATISTICS IO SET SHOWPLAN_ALL ON SET STATISTICS PROFILE ON SET 函數 ...
  • Apache Spark的工作原理 "Why Apache Spark" "關於Apache Spark" "如何安裝Apache Spark" " Apache Spark的工作原理" "spark彈性分散式數據集" "RDD持久性" "spark共用變數" "Spark SQL" "Spark ...
  • 1 概述 1 概述 已發佈【SqlServer系列】文章如下: 【SqlServer系列】SQLSERVER安裝教程 【SqlServer系列】資料庫三大範式 【SqlServer系列】表單查詢 【SqlServer系列】表連接 【SqlServer系列】子查詢 【SqlServer系列】開啟Sql ...
  • sql SqlServer 不可復讀和幻讀的定義,是根據自己的理解寫出來的,不是真正的定義,哈哈! 一、定義 1.臟讀 事務A向表中插入了一條數據,此時事務A還沒有提交,此時查詢語句能把這條數據查詢出來,這種現現象稱為臟讀;臟讀比較好理解 2.不可重覆讀 一個事務A第一次讀取的結果之後, 另外一個事 ...
  • 要麼用寫好的腳本重置root密碼,要麼自己手動運行命令重置密碼。 ...
  • 1、連接本地資料庫 2、連接遠程資料庫 3、導出資料庫 mysqldump u 用戶名 p 資料庫名 導出的文件名 4、導入資料庫 5、查看資料庫編碼格式 show variables like 'char%' 6、Like查詢傳參數 LIKE CONCAT('%', city, '%') 7、my ...
  • 安裝Nginx 1、首先添加nginx_signing.key(必須,否則出錯) 2、添加]Nginx](http://nginx.org/)官方提供的源 3、更新源並安裝Nginx 4、安裝Nginx完成後可查看版本號,輸入 1、添加PPA 2、安裝PHP5.6以及所需的一些擴展 3、配置PHP5 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...