問題:
在數據庫編程開發中,有時須要獲取一年前的日期,以便以此爲時間的分界點,查詢其先後對應的數據量。例如:
1. 想查詢截止到一年前當天0點以前的數據量,以及一年前當天0點開始到如今的數據量。
2. 想查詢截止到一年前當天24點以前的數據量,以及一年前當天24點開始到如今的數據量。
3. 想查詢截止到一年前當月1日0點以前的數據量,以及一年前當月1日0點開始到如今的數據量。
4. 想查詢截止到一年前當月最後一天24點以前的數據量,以及一年前當月最後一天24點開始到如今的數據量。
以上這四種狀況的具體查詢場景,有archive數據腳本開發以前對數據庫數據量的分佈狀況進行統計等,也有根據當前日期動態計算一年來的增量增幅狀況等。
若是每次接到這樣的需求須要獲取一年前日期,而後每次從新思考怎麼去實現確定是不明智的,或者說公司內已經有人寫了腳本實現,但其餘同事遇到相同的問題,又從新構思一次,這樣就比較浪費時間和精力,耗在這個細節上一些精力,有點像要作飯但是沒有米就要先去買米的感受,並且容易形成不一樣人寫的腳本不統一,不利於代碼規範化標準化的原則,不一樣的人跟進的時候還要去想一想以前的人寫的是什麼邏輯。並且從新開發腳本的話,又須要從新進行自測,不利於提升工做效率。html
解決方案:
首先簡單介紹一下基本的知識點:
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
腳本運行結果:
總結:
博主在這裏就爲你們分享了本身在工做過程當中所編寫的生成一年前日期數據庫腳本的方法,若是你也須要能夠直接拿來主義應用到實際工做中而不用進行重複構思編程。 spa