主頁 > 知識庫 > sql server編寫通用腳本實現(xiàn)獲取一年前日期的方法

sql server編寫通用腳本實現(xiàn)獲取一年前日期的方法

熱門標簽:百度競價排名 地方門戶網(wǎng)站 服務外包 AI電銷 鐵路電話系統(tǒng) 網(wǎng)站排名優(yōu)化 Linux服務器 呼叫中心市場需求

問題:

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

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

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

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

解決方案:

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

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個月,最后只截取年月日。

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

查詢統(tǒng)計時間節(jié)點之前:select count(*) from 表 where 時間字段 @datePoint

查詢統(tǒng)計時間節(jié)點開始到現(xiàn)在: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編寫通用腳本實現(xiàn)獲取一年前日期的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

您可能感興趣的文章:
  • sqlserver獲取當前日期的最大時間值
  • sqlserver中獲取當前日期的午夜的時間值的實現(xiàn)方法
  • SqlServer 查詢時日期格式化語句
  • SQL Server日期加減函數(shù)DATEDIFF與DATEADD用法分析
  • SQL Server 比較日期大小的方法
  • sql server日期相減 的實現(xiàn)詳解
  • SQL SERVER 日期格式轉換詳解
  • SQLserver中用convert函數(shù)轉換日期格式的方法
  • SqlServer中的日期與時間函數(shù)
  • SQLServer2005 按照日期自動備份的方法
  • Sqlserver 常用日期時間函數(shù)

標簽:衡水 崇左 黃山 仙桃 銅川 湖南 湘潭 蘭州

巨人網(wǎng)絡通訊聲明:本文標題《sql server編寫通用腳本實現(xiàn)獲取一年前日期的方法》,本文關鍵詞  ;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266