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

首頁 > 數(shù)據(jù)庫 > SQL Server > 正文

sql server 自定義分割月功能詳解及實現(xiàn)代碼

2024-08-31 01:04:15
字體:
供稿:網(wǎng)友

在最近的項目開發(fā)過程中,遇到了Sql server自動分割月的功能需求,這里在網(wǎng)上整理下資料.      

1、為何出現(xiàn)自定義分割月的需求

今天梳理一個平臺的所有函數(shù)時,發(fā)現(xiàn)了一個自定義分割月函數(shù),也就是指定分割月的開始日索引值(可以從1-31閉區(qū)間內(nèi)的任何一個值)來獲取指定日期所對應(yīng)的分割月數(shù)值。這個函數(shù)當(dāng)時是為了解決業(yè)務(wù)部門獲取非標(biāo)準(zhǔn)月(標(biāo)準(zhǔn)月就是從每個月的第一天到最后一天組成一個完成的標(biāo)準(zhǔn)月份)的統(tǒng)計匯總數(shù)據(jù)的。例如:如果指定分割月的開始日索引值為5則表示某個月的5號到下個月的4號之間作為一個完整的分割月;同樣地如果指定分割月的開始日索引值為1則表示標(biāo)準(zhǔn)月等等。 

我仔細(xì)梳理了這個函數(shù)進行了重構(gòu)簡化以及擴展,該自定義分割月函數(shù)的實現(xiàn)區(qū)別之前寫的SQL Server時間粒度系列----第3節(jié)旬、月時間粒度詳解文章中將一個整數(shù)值和月份日期相互轉(zhuǎn)換功能,這個是按照標(biāo)準(zhǔn)月來實現(xiàn)的,雖然思路大致相同,但是并沒有針對之前的月份日期和整數(shù)值轉(zhuǎn)換函數(shù)對來進行擴展而是獨立開發(fā)新的功能函數(shù)。也是為了盡量做到函數(shù)功能職責(zé)單一性、穩(wěn)定性、可維護性以及可擴展性。 

2、sql server實現(xiàn)自定義分割月功能 

自定義分割月功能函數(shù)包括兩個標(biāo)量函數(shù):ufn_SegMonths和ufn_SegMonth2Date。ufn_SegMonths獲取指定的日期在自定義分割月對應(yīng)的分割月數(shù)值;ufn_SegMonth2Date獲取指定一個分割月數(shù)值賭對應(yīng)的月份日期。 

sql server 版本的實現(xiàn)T-SQL代碼如下:

IF OBJECT_ID(N'[dbo].[ufn_SegMonths]', 'FN') IS NOT NULLBEGIN  DROP FUNCTION [dbo].[ufn_SegMonths];ENDGO --==================================-- 功能:根據(jù)自定義月開始索引值獲取指定日期所在的自定義月數(shù)。-- 說明:自定義分割月數(shù) = 年整數(shù)值*100 + 當(dāng)前所在分割月值。-- 環(huán)境:SQL Server 2005+。-- 調(diào)用:SET @intSegMonths = dbo.fn_SegMonths('2008-01-14', 15)。-- 創(chuàng)建:XXXX-XX-XX XX:XX-XX:XX XXX 創(chuàng)建函數(shù)實現(xiàn)。-- 修改:XXXX-XX-XX XX:XX-XX:XX XXX XXXXXXXX。--==================================CREATE FUNCTION [dbo].[ufn_SegMonths](   @dtmDate AS DATETIME            -- 日期  ,@tntSegStartIndexOfMonth AS INT = 15    -- 自定義分割月開始索引值(1-31))RETURNS INTASBEGIN    IF (@tntSegStartIndexOfMonth = 0 OR @tntSegStartIndexOfMonth >= 32)  BEGIN    SET @tntSegStartIndexOfMonth = 15;  END   DECLARE     @intYears AS INT    ,@tntMonth AS TINYINT    ,@sntDay AS SMALLINT;      SELECT     @intYears = DATEDIFF(YEAR, '1900-01-01', @dtmDate)    ,@tntMonth = DATEPART(MONTH, @dtmDate)    ,@sntDay = DATEPART(DAY, @dtmDate);   IF (@sntDay >= @tntSegStartIndexOfMonth)  BEGIN    SET @tntMonth = @tntMonth + 1;    END   IF (@tntMonth > 12)  BEGIN    SELECT       @intYears = @intYears + 1      ,@tntMonth = @tntMonth - 12;  END   RETURN @intYears * 100 + @tntMonth;ENDGO IF OBJECT_ID(N'[dbo].[ufn_SegMonths2Date]', 'FN') IS NOT NULLBEGIN  DROP FUNCTION [dbo].[ufn_SegMonths2Date];ENDGO --==================================-- 功能:獲取自定義分割月數(shù)對應(yīng)的自定義分割月日期。-- 說明:自定義分割月日期 = 自定義分割月數(shù)/100對應(yīng)的年整數(shù)日期“組合”當(dāng)前所在分割月值。-- 環(huán)境:SQL Server 2005+。-- 調(diào)用:SET @dtmSegMonthDate = dbo.fn_SegMonths2Date(11602)。-- 創(chuàng)建:XXXX-XX-XX XX:XX-XX:XX XXX 創(chuàng)建函數(shù)實現(xiàn)。-- 修改:XXXX-XX-XX XX:XX-XX:XX XXX XXXXXXXX。;--==================================CREATE FUNCTION [dbo].[ufn_SegMonths2Date](   @intSegMonths AS INT            -- 自定義分割月數(shù))RETURNS DATETIMEASBEGIN      DECLARE @dtmDefaultBasedate AS DATETIME;  SET @dtmDefaultBasedate = '1900-01-01';   IF ((@intSegMonths IS NULL) OR (@intSegMonths <= 0))  BEGIN    RETURN @dtmDefaultBasedate;  END   DECLARE     @intYears AS INT    ,@intMonth AS INT;    SELECT     @intYears = @intSegMonths / 100    ,@intMonth = @intSegMonths % 100;     RETURN DATEADD(MONTH, @intMonth - 1, DATEADD(YEAR, @intYears, @dtmDefaultBasedate));ENDGO 

3、測試驗證效果

 針對以上簡單的測試代碼如下:

DECLARE   @dtmStartDate AS DATETIME  ,@dtmEndDate AS DATETIME; SELECT   @dtmStartDate = '2000-01-01'  ,@dtmEndDate = '2016-12-31'; SELECT  [T1].*  ,[dbo].[ufn_SegMonths2Date]([T1].[SegMonths]) AS SegMonthDateFROM (  SELECT    [T].[CDate]    ,[dbo].[ufn_SegMonths]([T].[CDate], 28) AS SegMonths   FROM (    SELECT      DATEADD(DAY, [Num], @dtmStartDate) AS CDate    FROM      [dbo].[ufn_GetNums](0, DATEDIFF(DAY, @dtmStartDate, @dtmEndDate))  ) AS T  WHERE [T].[CDate] BETWEEN '2014-12-01' AND '2016-03-31') AS T1WHERE DATEPART(DAY, [T1].[CDate]) >= 27GO

效果截圖如下:

sql,server,自定義分割月,自定義分割月的實現(xiàn),自定義分割月詳解

 注意:以上測試代碼使用了SQL Server數(shù)字輔助表的實現(xiàn)這邊文章的內(nèi)聯(lián)表值函數(shù)ufn_GetNums。

 4、總結(jié)語

這次是梳理平臺的功能性函數(shù)所進行的重構(gòu)簡化以及擴展的實現(xiàn)。盡量將日期有關(guān)的功能函數(shù)梳理出來,便于直接在sql server用戶數(shù)據(jù)庫中來使用, 也便于BI倉庫中使用。國慶一來已經(jīng)過去一周,原來打算一周一遍的計劃還是延期啦,再次嚴(yán)重檢討自己。

  感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!


注:相關(guān)教程知識閱讀請移步到MSSQL教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
桃子视频成人app| 色一情一乱一区二区| 最新版天堂中文在线官网| 国产专区一区| 91欧美视频在线| 一区二区在线免费| 亚洲妇女屁股眼交7| 欧美 丝袜 自拍 制服 另类| 欧美成人精品一区二区综合免费| 亚洲激情第一区| 国产免费无遮挡吸奶头视频| 91小视频xxxx网站在线| 久久视频免费看| 久久影音资源网| 亚洲欧美自偷自拍| 久久久久久久久99精品大| 综合久久国产九一剧情麻豆| 97视频热人人精品免费| 波多野结衣高清视频| 在线观看色视频| 2019最新中文字幕| 77thz桃花论族在线观看| 永久免费av片在线观看全网站| 久久香蕉国产线看观看av| julia一区二区三区中文字幕| 欧美高清另类hdvideosexjaⅴ| 国内一卡2卡三卡四卡在线| 日韩av资源在线播放| av在线电影网站| 成人在线观看免费视频| 在线看的你懂得| 国产精品极品美女在线观看免费| 国产 欧美 日本| 视频一区在线观看| 嫩草影院一区二区| 欧美疯狂性受xxxxx另类| 国产v日韩v欧美v| 日韩少妇内射免费播放18禁裸乳| 国产一级免费大片| 亚洲人高潮女人毛茸茸| 男人的天堂av高清在线| 久久99精品国产一区二区三区| 国产福利一区二区三区视频| 亚洲ai欧洲av| 精品粉嫩超白一线天av| 少妇久久久久久被弄到高潮| 性久久久久久久久久| 精品999视频| 亚洲一线二线三线久久久| 欧洲视频一区| 久久激情五月丁香伊人| 亚洲网一区二区三区| 在线黄色免费网站| 粉嫩91精品久久久久久久99蜜桃| 男女作爱免费网站| 亚洲肉体裸体xxxx137| 久久国产精品国语对白| 一区二区三区四区乱视频| 中文字幕在线看人| 亚洲午夜久久久久久久久红桃| 久久男人的天堂| 欧美羞羞视频| 欧美超碰在线| 中文字幕在线观看免费高清| 亚洲欧美日韩另类精品一区二区三区| 成人18免费入口| 爆操妹子视频在线观看| 日韩欧美国产午夜精品| h版电影在线播放视频网站| 天天躁夜夜躁狠狠是什么心态| 交视频在线观看国产| 欧美日韩精品免费在线观看视频| 欧美一区二区美女| 欧美变态另类刺激| 国产精品高精视频免费| 亚洲国产一区在线观看| 在线视频不卡一区二区| 免费视频国产一区| 欧美激情中文字幕在线| 91精品国产99久久久久久红楼| 五月婷婷之综合激情| 国产精品v欧美精品v日韩| 韩国在线一区| 亚洲午夜成aⅴ人片| 日本免费一区二区三区视频观看| www婷婷av久久久影片| 欧美精选视频在线观看| 久久综合亚洲色hezyo国产| 中文国产成人精品久久一| 色无极影院亚洲| 久久国产精品免费观看| 免费人成a大片在线观看动漫| 日本道免费精品一区二区三区| 国产精品视频成人| 欧美黑人性受xxxx精品| 91美女片黄在线观看91美女| 精品国产91久久久久久久妲己| 好男人www在线视频| 国产免费无遮挡吸奶头视频| 青青九九免费视频在线| 折磨小男生性器羞耻的故事| 成人在线观看你懂的| 少妇精品久久久久久久久久| 亚洲人成小说| 欧美精品久久96人妻无码| 自拍视频网站| 一区二区三区免费观看视频| 国产精品三级av在线播放| 中文字幕中文字幕在线中一区高清| 亚洲一区二区久久久久久| 日韩视频一区二区三区在线播放免费观看| 中文字幕av免费专区久久| 精品一区二区三区人妻| 欧美精品99久久久| 日韩欧美在线免费观看视频| 日本久久中文字幕| 欧美午夜免费影院| 精品婷婷伊人一区三区三| 精品国产免费人成在线观看| 日本成人在线视频网站| 成人在线免费播放视频| 视频免费观看| 欧美日韩的一区二区| 蜜桃一区二区| 日本午夜精品理论片a级appf发布| 精品一区二区在线欧美日韩| 欧美国产日韩综合| 曰本三级日本三级日本三级| 成人av免费看| 小视频福利在线| 日本vs亚洲vs韩国一区三区| 成人h动漫精品一区二| 91精品国产色综合久久ai换脸| 国产熟女一区二区三区五月婷| 麻豆精品一区二区av白丝在线| 疯狂揉花蒂控制高潮h| 国产成人精品久久| 超碰中文字幕在线观看| 日本黄色激情视频| 热99精品只有里视频最新| 欧美成人中文字幕在线| 男人用嘴添女人下身免费视频| 日韩精品一区二区三区视频在线观看| 人人做人人澡人人爽欧美| 日韩欧美视频免费在线观看| 成年男女免费视频网站不卡| 亚洲人成精品久久久久| 国产精品视频一区二区三区四| 成人一级片在线观看| 97久久视频| 亚洲午夜久久久久久久久电影院| 国产劲爆久久| 高清一区二区视频| 欧美情侣在线播放| 亚洲人成小说| 欧美日韩国产不卡| 91麻豆一二三四在线| 国产调教打屁股xxxx网站| 欧美成人女星排名| 色噜噜成人av在线| 98精品国产高清在线xxxx天堂| 免费不卡av| 欧美一区二区三区精品电影| 亚洲伊人成综合成人网| 欧美日韩国产综合视频在线观看| 可以免费观看av的网站| 日韩高清在线观看| 鲁丝一区鲁丝二区鲁丝三区| 9l国产精品久久久久麻豆| 欧美一区二区私人影院日本| 韩国理伦片久久电影网| 国产一区二区三区久久| 国产视频一区在线| 91丨九色丨蝌蚪丨少妇在线观看| 91久久精品日日躁夜夜躁欧美| 91成人国产综合久久精品| 欧美一区二区三区红桃小说| www.久久com| 欧美激情高清视频| 日韩综合中文字幕| 男女爽爽爽视频| 日韩欧美字幕| 国产精伦一区二区三区| 国产xxxxx在线观看| 亚洲婷婷在线| 国产精品成久久久久| 亚洲欧美日韩国产成人精品影院| 久久国产精品亚洲| 怕怕欧美视频免费大全| 国产精品久久麻豆| 亚洲高清无码久久| 极品少妇一区二区三区| 性欧美又大又长又硬| 丁香5月婷婷久久| 动漫精品一区二区| 神马电影久久| 天海翼在线视频| 国产精品视频一区麻豆| 国产91社区| 久久香蕉精品视频| av一区在线播放| 国产免费无码一区二区| 欧美高清性xxxxxxx| 中文字幕成人精品久久不卡| 日韩欧美一区二区三区四区| 亚洲色图偷拍自拍| 美州a亚洲一视本频v色道| 色就色 综合激情| 三上悠亚激情av一区二区三区| 国产成人亚洲综合无码| av在线天天| 日韩av影院在线观看| 一区二区三区在线免费播放| www..com国产| 亚洲AV无码成人精品一区| 美日韩丰满少妇在线观看| 色婷婷久久99综合精品jk白丝| 国产美女视频免费观看下载软件| 91九色02白丝porn| 亚洲精品7777xxxx青睐| 午夜在线视频| 久久亚洲综合国产精品99麻豆精品福利| 91精品久久久久久久久久久久久久| 91精品国产色综合久久不卡98| 亚洲成**性毛茸茸| 日韩精品成人一区二区三区| 日韩av一级| 蜜臀av免费观看| 国产精品日日摸夜夜摸av| 国产五月天婷婷| 91丨porny丨中文| 九色成人国产蝌蚪91| 婷婷久久国产对白刺激五月99| 亚洲国产精品视频| 伊人青青综合网| 亚洲区一区二区三区| 国产成人自拍网站| 国产精品熟女一区二区不卡| 91青草视频久久| 亚洲**2019国产| 加勒比中文字幕精品| 51色欧美片视频在线观看| 极品尤物av丝袜美腿在线观看| 中文在线免费视频| 免费在线稳定资源站| 亚洲午夜激情视频| 国产精品视频一区二区在线观看| 美女av在线免费观看| 美国成人xxx| 欧美动物xxx| 国模套图日韩精品一区二区| 国产精品二区在线| 国产免费播放一区二区| 中文字幕国产视频| 久久9精品区-无套内射无码| 黄色免费观看网站| 在线亚洲精品| 88国产精品欧美一区二区三区| 国产精品theporn| 手机在线一区二区三区| 青草视频在线播放| 亚洲人成色777777精品音频| 国产91精品看黄网站在线观看| 欧美激情一区在线| 不卡视频在线| 偷拍亚洲精品| 日韩在线观看中文字幕| 精品国产乱码一区二区| 5858s免费视频成人| 玖玖在线精品| 亚洲污视频在线观看| 一区二区三区四区五区视频在线观看| 成人欧美一区二区三区黑人孕妇| 四虎永久在线| www.av在线.com| 色偷偷亚洲女人天堂观看欧| 蜜臀av性久久久久av蜜臀妖精| 男人的天堂亚洲在线| 日韩av一卡| 日本欧美电影在线观看| 在线观看亚洲视频啊啊啊啊| 免费观看成人性生生活片| 亚洲一区二区三区精品动漫| 99精品视频在线免费观看| 日韩国产在线观看一区| 日韩护士脚交太爽了| 久久久99999| 亚洲国产成人精品激情在线| 亚洲都市激情| 91综合网人人| 精品日韩成人av| 久草国产视频| 黄色免费视频观看| 日本免费一区二区六区| 91国偷自产一区二区使用方法| 青青青国产在线| 久久亚洲综合国产精品99麻豆精品福利| 成年人免费在线观看网站| 中文字幕在线观| 一级性生活大片| www.涩涩爱| 91老司机福利 在线| 性感女国产在线| 在线观看亚洲色图| 四虎影视国产精品| 日韩免费毛片视频| 欧美久久久久久久久中文字幕| 影音日韩av| 蜜桃视频在线观看免费视频| 草草影院在线| 秋霞影院一区二区三区| 青娱乐精品在线视频| www深夜成人a√在线| 久久久久久久久久99| 超碰国产精品一区二页| 久久精品在线免费视频| 色欲狠狠躁天天躁无码中文字幕| 欧美色视频免费| 99精品在线观看视频| 国产精品美女久久久久久久久久久| 波多野结衣三级视频| 中文字幕免费高清| 国产日韩亚洲欧美精品| 日韩精品欧美成人高清一区二区| 日韩精品在线视频免费观看| 日本一道高清亚洲日美韩| 久久九九久精品国产免费直播| 爱情电影社保片一区|