1. 程式人生 > 資料庫 >sql server編寫通用指令碼實現獲取一年前日期的方法

sql server編寫通用指令碼實現獲取一年前日期的方法

問題:

  在資料庫程式設計開發中,有時需要獲取一年前的日期,以便以此為時間的分界點,查詢其前後對應的資料量。例如:

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,getdate()),120)
select @datePoint as DatePoint
go
--2.截止到一年前當天24點
declare @datePoint datetime = convert(varchar(10),dateadd(day,getdate())),120)
select @datePoint as DatePoint
go
--3.截止到一年前當月1日0點
declare @datePoint datetime = convert(varchar(10),convert(varchar(7),getdate(),120) + '-01'),120)
select @datePoint as DatePoint
go
--4.截止到一年前當月最後一天24點
declare @datePoint datetime = convert(varchar(10),dateadd(month,120) + '-01')),120)
select @datePoint as DatePoint
go

指令碼執行結果:

總結

以上所述是小編給大家介紹的sql server編寫通用指令碼實現獲取一年前日期的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對我們網站的支援!
如果你覺得本文對你有幫助,歡迎轉載,煩請註明出處,謝謝!