日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

SQLServer實現Ungroup操作的示例代碼

瀏覽:287日期:2023-09-25 20:57:30
目錄概要代碼和實現代碼和實現基本思路代碼第1輪查詢第2輪查詢第3輪查詢第4輪查詢代碼改進附錄概要

我們經常在SQL Server中使用group by語句配合聚合函數,對已有的數據進行分組統計。本文主要介紹一種分組的逆向操作,通過一個遞歸公式,實現ungroup操作。

代碼和實現

我們看一個例子,輸入數據如下,我們有一張產品表,該表顯示了產品的數量。

要求實現Ungroup操作,最后輸出數據如下:

代碼和實現基本思路

要想實現ungroup,顯然需要表格的自連接。自連接的次數取決于total_count的數量。

代碼

自連接操作過程中涉及大量的子查詢,為了便于代碼后期維護,我們采用CTE。每次子查詢,total_count自動減一,total_count小于0時,直接過濾掉,該數據不再參與查詢。

第1輪查詢

獲取全部total_count 大于0的數據,即全表數據。

with cte1 as (select * from products where total_count > 0),

輸出結果:

第2輪查詢

第2輪子查詢,以第1輪的輸出作為輸入,進行表格自連接,total_count減1,過濾掉total_count小于0的產品。

with cte1 as (select * from products where total_count > 0),cte2 as (select * from (select cte1.id, cte1.name, (cte1.total_count -1) as total_count from cte1join products p1 on cte1.id = p1.id) t where t.total_count > 0)select * from cte2

輸出結果是:

和第1輪相比較,輸出結果中沒了Flashlight了,因為它的total_count減1后為0,被過濾了。

第3輪查詢

第3輪子查詢,以第2輪的輸出作為輸入,進行表格自連接,total_count減1,過濾掉total_count小于0的產品。

with cte1 as (select * from products where total_count > 0),cte2 as (select * from (select cte1.id, cte1.name, (cte1.total_count -1) as total_count from cte1join products p1 on cte1.id = p1.id) t where t.total_count > 0),cte3 as (select * from (select cte2.id, cte2.name, (cte2.total_count -1) as total_count from cte2join products p1 on cte2.id = p1.id) t where t.total_count > 0)select * from cte3

輸出結果如下:

第4輪查詢

第4輪子查詢,以第3輪的輸出作為輸入,進行表格自連接,total_count減1,過濾掉total_count小于0的產品。

with cte1 as (select * from products where total_count > 0),cte2 as (select * from (select cte1.id, cte1.name, (cte1.total_count -1) as total_count from cte1join products p1 on cte1.id = p1.id) t where t.total_count > 0),cte3 as (select * from (select cte2.id, cte2.name, (cte2.total_count -1) as total_count from cte2join products p1 on cte2.id = p1.id) t where t.total_count > 0),cte4 as (select * from (select cte3.id, cte3.name, (cte3.total_count -1) as total_count from cte3join products p1 on cte3.id = p1.id) t where t.total_count > 0)select * from cte4

輸出結果:

下一次迭代,compass的total_count也將等于0,被過濾掉,查詢結果不會再有新的記錄,所以查詢結束。我們將cte1,cte2,cte3 和 cte4 合并,合并結果即是所求。

代碼改進

顯然上述代碼過于冗長,如果產品數量很多,那子查詢的代碼也將大幅度增加。

事實上,從第2輪到第4輪的子查詢,代碼是非常相近的,對于這種情況,無論任何開發語言,我們都可以采用遞歸的方式進行優化處理。對于此類為題,遞歸公式如下:

with CTE as (initial query -- 初始查詢union all -- 查詢結果合并recursive query -- 遞歸部分,即在查詢中直接引用CTERecursive terminatation condition -- 遞歸終止條件)

初始查詢,就是我們的第1輪迭代。遞歸部分,就是我們所謂的相似代碼部分。

對于遞歸終止條件,默認是如果沒有新的記錄參加遞歸,則遞歸終止。本例是按照業務邏輯,設置的終止條件,即total_count需要大于0,這樣也可以做到過濾到最后,不會再有新的記錄參與到遞歸中。

按照上述供述,得到的查詢代碼如下:

with cte as (select * from products where total_count > 0union allselect * from (select cte.id, cte.name, (cte.total_count -1) as total_count from ctejoin products p1 on cte.id = p1.id) t where t.total_count > 0)select id, name from cteorder by id, name

當我們使用CTE時候,發現每次查詢的代碼類似,就可以考慮采用上述遞歸公式對代碼進行優化。找到初始查詢結果,在相似的代碼中找到遞歸部分以及遞歸終止條件。

附錄

建表和數據初始化代碼

if OBJECT_ID('products', 'U') is not null drop table productscreate table products (id int primary key identity(1,1),name nvarchar(50) not null,total_count int not null)insert into products (name, total_count) values ('Water Bottle', 3),('Tent', 2),('Flashlight', 1),('compass',4)

到此這篇關于SQLServer實現Ungroup操作的示例代碼的文章就介紹到這了,更多相關SQLServer Ungroup操作內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: MsSQL 數據庫
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲精品欧美| 亚洲伦乱视频| 青青伊人久久| 久久国产生活片100| 日本免费在线视频不卡一不卡二| 亚洲午夜91| 亚洲欧美日韩精品一区二区| 国产精品88久久久久久| 中文日韩在线| 欧美亚洲免费| 国产综合婷婷| 亚洲精品九九| 国产劲爆久久| bbw在线视频| 久久青草久久| 亚洲图片久久| 国产不卡一区| 免费不卡中文字幕在线| 欧美国产美女| 红桃视频亚洲| 麻豆精品av| 日韩一区二区久久| 亚洲精品系列| 精品亚洲免a| 男人的天堂久久精品| 精品三区视频| 欧美日韩国产传媒| 久久精品999| 欧美中文字幕一区二区| 五月亚洲婷婷 | 日韩精品1区2区3区| 超碰在线99| 麻豆亚洲精品| 日韩成人精品一区| 国产一卡不卡| 亚洲一级特黄| 国产成人1区| 国产日韩一区二区三区在线 | 国产一区二区三区四区五区| 亚洲激情二区| 国产激情在线播放| 久久麻豆视频| 日韩激情av在线| 模特精品在线| 视频一区中文| 91精品精品| 丝袜诱惑一区二区| 国产一区二区三区视频在线| 亚洲视频国产精品| 久久视频一区| 久久久国产亚洲精品| 成人在线观看免费视频| 日韩专区欧美专区| 国产主播一区| 黑人精品一区| 国产aa精品| 日韩a一区二区| 国产精选在线| 日韩av在线中文字幕| 国产精品久久久久久久免费观看| 日韩av福利| 久久人人99| 黑丝一区二区三区| 亚洲欧美日韩国产| 亚洲毛片在线免费| 91精品国产自产在线丝袜啪| 日韩一区二区三区精品| 亚洲另类黄色| 欧美日韩一区二区高清| 国产极品久久久久久久久波多结野| 欧美日韩一区二区三区不卡视频| 国产日韩1区| 精品99在线| 欧美va天堂| 偷拍亚洲精品| 91日韩欧美| 亚洲免费影院| 国产精品巨作av| 国产一区一一区高清不卡| 午夜av成人| 亚洲毛片视频| 精品国产欧美| 欧美成人精品| 青青草精品视频| 精品国产一区二区三区av片| 久久精品成人| 日韩国产在线观看| 国产高潮在线| 日本免费在线视频不卡一不卡二| 国产精选在线| 亚洲日韩中文字幕一区| 国产h片在线观看| 免费日韩一区二区| 国产成人免费精品| 日韩在线卡一卡二| 国产美女高潮在线| 日本色综合中文字幕| 中文字幕色婷婷在线视频| 只有精品亚洲| 99久久激情| 久久精品国产在热久久| 视频一区二区三区在线| 日韩理论片av| 欧美国产极品| 日韩中文字幕无砖| 九九综合九九| 日韩大片在线观看| 欧美片第1页综合| 国产亚洲一区在线| 久久久久国产精品一区三寸| 欧美一级一区| 天堂va欧美ⅴa亚洲va一国产| 日韩高清欧美| 国产精品腿扒开做爽爽爽挤奶网站| sm久久捆绑调教精品一区| 国产精品白丝久久av网站| 亚洲免费资源| 亚洲天堂免费| 久久亚洲电影| 日韩一级精品| 亚洲少妇诱惑| 喷白浆一区二区| 久久亚洲欧美| 日韩欧美三区| 欧美日韩视频免费看| 日本在线视频一区二区| 日产欧产美韩系列久久99| 国模 一区 二区 三区| 久久久久久久久久久妇女 | 亚洲激精日韩激精欧美精品| 国产中文一区| 91久久久久| 国产麻豆综合| 日韩有吗在线观看| 亚洲精品伊人| 国产情侣久久| 久久国内精品自在自线400部| 久久亚洲美女| 日韩不卡一区二区三区 | 国产精品日韩精品在线播放| 久久免费影院| 色婷婷精品视频| 亚洲高清不卡| 成午夜精品一区二区三区软件| 国产精品xx| 9色国产精品| 日本v片在线高清不卡在线观看| 欧美日韩中出| 日本高清不卡一区二区三区视频| 亚洲精品在线观看91| 综合国产视频| 国产女人18毛片水真多18精品| 黄色网一区二区| 制服诱惑一区二区| 欧美日本不卡高清| 亚洲播播91| 日韩av中文字幕一区| 日韩在线第七页| 色综合视频一区二区三区日韩 | 久久久久久久久丰满| 亚洲麻豆一区| 激情黄产视频在线免费观看| 香蕉国产精品| 麻豆一区在线| 蜜臀91精品一区二区三区| 久久不见久久见中文字幕免费 | 亚洲精品三级| 久久精品国产99国产精品| 亚洲欧美高清| 午夜久久中文| 国产精品一页| 免费在线观看一区二区三区| 丝袜诱惑一区二区| 麻豆成人av在线| 日韩精品导航| 视频在线观看一区| 欧美日韩少妇| 欧美片第1页| 九九99久久精品在免费线bt| 日韩高清电影一区| 国产亚洲精品久久久久婷婷瑜伽| 久久一二三区| 亚洲福利专区| 日韩精品专区| 亚洲精品成人图区| 免费在线亚洲| 国产精品xxx在线观看| 午夜精品福利影院| 日韩欧美2区| 亚洲人成高清| 日韩中文字幕不卡| 免费精品视频在线| 亚洲欧美日韩国产| 中文字幕一区二区三区日韩精品 | 美女精品在线| 亚洲一区二区网站| 久久五月天小说| 欧美粗暴jizz性欧美20| 99riav1国产精品视频| 欧美午夜不卡影院在线观看完整版免费|