下載吧 - 綠色安全的游戲和軟件下載中心

          軟件下載吧

          當前位置:軟件下載吧 > 數據庫 > MS_SQL > SQL開發知識:sql server編寫通用腳本實現獲取一年前日期的方法

          SQL開發知識:sql server編寫通用腳本實現獲取一年前日期的方法

          時間:2024-03-11 15:08作者:下載吧人氣:16

          問題:

            在數據庫編程開發中,有時需要獲取一年前的日期,以便以此為時間的分界點,查詢其前后對應的數據量。例如:

          1. 想查詢截止到一年前當天0點之前的數據量,以及一年前當天0點開始到現在的數據量。
          2. 想查詢截止到一年前當天24點之前的數據量,以及一年前當天24點開始到現在的數據量。
          3. 想查詢截止到一年前當月1日0點之前的數據量,以及一年前當月1日0點開始到現在的數據量。
          4. 想查詢截止到一年前當月最后一天24點之前的數據量,以及一年前當月最后一天24點開始到現在的數據量。

            以上這四種情況的具體查詢場景,有archive數據腳本開發之前對數據庫數據量的分布情況進行統計等,也有根據當前日期動態計算一年來的增量增幅情況等。

            如果每次接到這樣的需求需要獲取一年前日期,然后每次重新思考怎么去實現肯定是不明智的,或者說公司內已經有人寫了腳本實現,但其他同事遇到相同的問題,又重新構思一次,這樣就比較浪費時間和精力,耗在這個細節上一些精力,有點像要做飯可是沒有米就要先去買米的感覺,而且容易造成不同人寫的腳本不統一,不利于代碼規范化標準化的原則,不同的人跟進的時候還要去想想之前的人寫的是什么邏輯。而且重新開發腳本的話,又需要重新進行自測,不利于提高工作效率。

          解決方案:

            首先簡單介紹一下基本的知識點:

          getdate()是獲取當前日期;
          dateadd可以對日期進行增減,在這里用來對年份減少1【dateadd(year, -1, 日期字符串)】,也可以用來對月份增加1【dateadd(month, 1, 日期字符串)】;
          convert可以對日期進行字符串截取轉換操作,在這里可以只截取形如2019-07-17的年月日【convert(varchar(10), 日期字符串, 120))】,也可以只截取形如2019-07的年月部分【convert(varchar(7), 日期字符串, 120))】。  

          然后就是針對上面4個問題對應的4個解決方法:

          1. 最簡單,對當前日期進行減少1年的運算,然后只截取年月日。
          2. 先對當前日期進行增加1天的運算,然后再減少1年,最后只截取年月日。
          3. 先對當前日期進行截取年月操作,然后再指定為當月01日,再減少1年,最后只截取年月日。
          4. 先對當前日期進行截取年月操作,然后再指定為當月01日,再減少1年,并加上1個月,最后只截取年月日。

            最后就可以直接在查詢腳本條件中使用這個時間節點:

          查詢統計時間節點之前:select count(*) from 表 where 時間字段 < @datePoint

          查詢統計時間節點開始到現在:select count(*) from 表 where 時間字段 >= @datePoint

          腳本:

          /*
          功能:獲取一年前日期
          作者:zhang502219048
          腳本來源:https://www.cnblogs.com/zhang502219048/p/11198789.html
          */
          –1.截止到一年前當天0點
          declare @datePoint datetime = convert(varchar(10), dateadd(year, -1, getdate()), 120)
          select @datePoint as DatePoint
          go
          –2.截止到一年前當天24點
          declare @datePoint datetime = convert(varchar(10), dateadd(year, -1, dateadd(day, 1, getdate())), 120)
          select @datePoint as DatePoint
          go
          –3.截止到一年前當月1日0點
          declare @datePoint datetime = convert(varchar(10), dateadd(year, -1, convert(varchar(7), getdate(), 120) + ‘-01’), 120)
          select @datePoint as DatePoint
          go
          –4.截止到一年前當月最后一天24點
          declare @datePoint datetime = convert(varchar(10), dateadd(month, 1, dateadd(year, -1, convert(varchar(7), getdate(), 120) + ‘-01’)), 120)
          select @datePoint as DatePoint
          go

          標簽MSSQL,SQLServer,技術文檔,數據庫,SQLSERVER

          相關下載

          查看所有評論+

          網友評論

          網友
          您的評論需要經過審核才能顯示

          熱門閱覽

          最新排行

          公眾號

          主站蜘蛛池模板: 无码毛片视频一区二区本码| 亚洲一区二区三区在线| 综合久久久久久中文字幕亚洲国产国产综合一区首 | 日韩免费一区二区三区| 精品人妻少妇一区二区| 亚洲一区二区三区偷拍女厕| 少妇激情AV一区二区三区| 国产精品制服丝袜一区| 高清无码一区二区在线观看吞精| 亚洲AV无码一区二区三区国产| 久久无码精品一区二区三区| 日韩亚洲AV无码一区二区不卡| 天堂va在线高清一区| 蜜桃视频一区二区| 精品欧洲av无码一区二区| 国产伦精品一区二区三区精品| 亚洲无人区一区二区三区| 韩国福利一区二区美女视频| 国产在线观看一区二区三区精品| 中文字幕日韩一区二区三区不卡| 国产成人精品一区二区三在线观看| 久久精品一区二区三区不卡| 国产视频一区在线播放| 无码国产精品一区二区免费I6| 中文字幕一精品亚洲无线一区| 国产一区二区三区国产精品| 无码人妻一区二区三区免费看| 国产高清在线精品一区小说| 国产精品日韩一区二区三区| 蜜桃视频一区二区三区在线观看| 国产AV国片精品一区二区| 国产一区美女视频| 无码精品蜜桃一区二区三区WW| 久久久无码精品国产一区| 国产福利电影一区二区三区久久久久成人精品综合 | 国产精品亚洲一区二区三区久久| 少妇精品无码一区二区三区| 久久久久人妻精品一区| 2021国产精品一区二区在线| 日本免费一区二区三区四区五六区| 国精品无码A区一区二区|