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

首頁 > 開發 > 綜合 > 正文

[MSSQL]SQL疑難雜癥實戰記錄-巧妙利用PARTITION分組排名遞增特性解決合并連續相同數據行

2024-07-21 02:49:33
字體:
來源:轉載
供稿:網友
[MSSQL]SQL疑難雜癥實戰記錄-巧妙利用PARTITION分組排名遞增特性解決合并連續相同數據行問題提出

先造一些測試數據以說明題目:

DECLARE @TestData TABLE(ID INT,Col1 VARCHAR(20),Col2 VARCHAR(20)) INSERT INTO @TestData(ID,Col1,Col2) SELECT 1,'New','ApPRoved' UNION ALL SELECT 2,'Approved','Commited' UNION ALL SELECT 3,'Commited','In Progress' UNION ALL SELECT 4,'New','Approved' UNION ALL SELECT 5,'New','Approved' UNION ALL SELECT 6,'New','Approved' UNION ALL SELECT 7,'Approved','Removed' SELECT * FROM @TestData

image

image

 

數據說明,ID列連續自增,列1和列2都是TFS中PBI的狀態記錄,就是從什么變更到什么,如新建到批準,批準到提交神馬的

現在要求連續且相同的狀態變更記錄合并,不連續或者不同的狀態變更保留,例如:

以上圖為例,ID為1,4,5,6的記錄都是從NewApproved狀態,但是記錄1與記錄4、5、6不相鄰,或者說不連續,那么就要分成兩組,

記錄1一組,記錄4、5、6一組,其它記錄因為狀態變更不相同所以全部保留,最后的查詢結果應該長成下圖這個樣子:

image

繼續之前你可以先自己試下,這可能會帶來新的解題思路,

 

解題思路

該問題的關鍵在于GROUP BY會把記錄1、4、5、6合并在一起,而這不符合要求,僅需要合并4、5、6,源表里沒有這樣一個字段可以將記錄1與記錄4、5、6區分開來,這是解題的關鍵

這里可以利用RANK函數配合使用PARTITION關鍵字,首先把1456分到一組去,同時產生一個組內排名的新字段R,這個排名R很關鍵,后邊會用到,見下圖:

image

RANK函數不了解的點這里

RANK函數以Col1 + Col2為分組條件,這樣分成了四組,分別是New-Approved、Approved-Commited、Commited-In Progress、Approved-Removed

在New-Approved組內,記錄1、4、5、6分別排名1、2、3、4;其它組內僅一條記錄,在其組內排名均為1

現在制造了一個R字段,R字段標識了每條記錄在其組內的排名,排名自1開始遞增,

源表內ID自增,組內排名R遞增,這就是解題的關鍵,

當連續相同的記錄出現時,其ID與其排名R在同時遞增,則其差值是相同的,拿到這個差值就可以很容易解決題目了,看下圖:

image

記錄4、5、6相同且連續出現,其ID與其排名在同時增長,其差值則保持不變,這里使用Col1 + Col2 + Gap作為分組條件即可將記錄4、5、6合并,再取個最小ID出來,問題解決,完整腳本如下:

image

可是如果ID不連續時怎么辦呢?這個不難,參考[MSSQL]ROW_NUMBER函數


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美性受xxxx黑人猛交| 日韩精品黄色网| 久久资源免费视频| 精品国产一区二区三区在线观看| 亚洲欧美一区二区三区在线| 成人美女免费网站视频| 91精品国产91久久久| 2021久久精品国产99国产精品| 91国内产香蕉| 精品成人av一区| 久久久国产一区二区三区| 久久久久久久av| 欧美日韩免费观看中文| 亚洲国产免费av| 欧美大片免费观看在线观看网站推荐| 亚洲免费精彩视频| 欧美一区视频在线| 91av在线免费观看| 色视频www在线播放国产成人| 国模精品一区二区三区色天香| 亚洲第一页在线| 国产成人精彩在线视频九色| 夜夜躁日日躁狠狠久久88av| 国产视频欧美视频| 中文字幕日韩精品在线| 狠狠躁天天躁日日躁欧美| 国产成人精品久久久| 日韩精品极品视频免费观看| 久久天天躁狠狠躁夜夜躁| 动漫精品一区二区| 欧美精品生活片| 亚洲精品国产suv| 精品国产31久久久久久| 欧美激情国产高清| 欧美一区二区.| 国产91精品最新在线播放| 欧美日韩成人黄色| 在线视频国产日韩| 美日韩精品免费视频| 国产亚洲精品久久久久久牛牛| 国产性猛交xxxx免费看久久| 精品国产乱码久久久久酒店| 日本精品性网站在线观看| 中文字幕亚洲一区在线观看| 国产一区二区三区18| 91精品久久久久久久| 亚洲va欧美va国产综合剧情| 成人久久一区二区| 在线播放国产一区中文字幕剧情欧美| 日韩中文字幕在线视频播放| 欧美高清视频在线播放| 欧洲成人性视频| 青青草国产精品一区二区| 亚洲人免费视频| 国产精品一区二区三| 国模精品一区二区三区色天香| 精品国产一区二区三区久久狼5月| 亚洲色图17p| 亚洲精品久久久久久久久久久久| 久久久免费精品视频| 国产美女直播视频一区| 日韩综合视频在线观看| 亚洲精品suv精品一区二区| 成人性生交xxxxx网站| 一区二区三区视频免费在线观看| 久久艹在线视频| 精品久久久久久中文字幕| 国产一区二区三区在线观看视频| 亚洲最大福利视频网站| 欧美一级大片视频| 日韩综合视频在线观看| 欧美日本啪啪无遮挡网站| 国产欧美一区二区三区在线看| 久久精品在线播放| 亚洲精品女av网站| 欧美黄色片视频| 精品国产老师黑色丝袜高跟鞋| 尤物yw午夜国产精品视频明星| 欧美一级淫片丝袜脚交| 亚洲福利影片在线| 欧美高清视频一区二区| 国产精品www网站| 欧美乱大交xxxxx另类电影| 91日本在线视频| 色无极亚洲影院| 久久香蕉国产线看观看av| 亚洲伦理中文字幕| 亚洲精品99999| 91精品久久久久久久久久另类| 日韩av不卡电影| 欧美大片免费观看在线观看网站推荐| 日本成熟性欧美| 成人a级免费视频| 成人免费高清完整版在线观看| 性欧美xxxx视频在线观看| 欧美在线视频观看免费网站| 毛片精品免费在线观看| 亚洲国产欧美久久| 91人人爽人人爽人人精88v| 91欧美精品成人综合在线观看| 亚洲精品资源美女情侣酒店| 欧美裸体视频网站| 97视频网站入口| 韩国国内大量揄拍精品视频| 91香蕉嫩草神马影院在线观看| 欧美日韩xxxxx| 成人情趣片在线观看免费| 国产成人aa精品一区在线播放| 欧美大片va欧美在线播放| 欧美日韩一区二区免费视频| 精品成人久久av| 97国产精品免费视频| 欧美视频中文在线看| 欧美精品18videos性欧美| 成人在线小视频| 97在线看免费观看视频在线观看| 欧洲成人午夜免费大片| 不卡在线观看电视剧完整版| 国产成人精品a视频一区www| 日韩欧美国产成人| 国产网站欧美日韩免费精品在线观看| 97视频免费在线看| 久久国产精品99国产精| 欧美黑人xxxx| 久久天天躁夜夜躁狠狠躁2022| 精品国产一区二区三区四区在线观看| 福利视频导航一区| 伊人久久久久久久久久久久久| 岛国精品视频在线播放| 一区二区三区日韩在线| 久久久久久久999| 亚洲欧美成人一区二区在线电影| 韩日欧美一区二区| 久久久伊人欧美| 国内精品视频在线| 久久久精品免费| 国产精品丝袜一区二区三区| 欧美极品少妇全裸体| 伊人久久五月天| 日韩在线观看高清| 成人欧美在线视频| 成人伊人精品色xxxx视频| 中文字幕精品www乱入免费视频| 亚洲精品中文字幕有码专区| 国产欧美一区二区三区四区| 91最新国产视频| 亚洲毛片在线看| 91av在线播放视频| 国产成人av网| 97视频在线免费观看| 久久久久久久久久久人体| 国产一区二区激情| 欧美丰满老妇厨房牲生活| 国产精品jizz在线观看麻豆| 日韩色av导航| 久久久久久久久久久91| 久久综合免费视频影院| 久久久噜久噜久久综合| 欧美综合国产精品久久丁香| 亚洲国产日韩欧美在线99| 久久久久久久久久久av| 亚洲视频在线观看视频| 中国人与牲禽动交精品| www.精品av.com|