您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關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, -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
腳本運行結果:
感謝各位的閱讀!關于“sql server編寫通用腳本如何實現獲取一年前日期”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。