一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Sql Server - sql server編寫通用腳本實現獲取一年前日期的方法

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

2020-05-29 16:09張工502219048 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

腳本:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
/*
 功能:獲取一年前日期
 作者: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編寫通用腳本實現獲取一年前日期的方法

總結

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

原文鏈接:https://www.cnblogs.com/zhang502219048/archive/2019/07/17/11198789.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲经典激情春色另类 | 99草精品视频 | 国产伦码精品一区二区 | 91视频破解 | 欧美一区二区日韩一区二区 | 久久一本岛在免费线观看2020 | 亚洲精品国产在线网站 | 亚洲丰满女人ass硕大 | 亚洲卡一卡2卡三卡4麻豆 | 亚洲性综合网 | 国产精品免费aⅴ片在线观看 | 91亚洲视频在线观看 | 国内精品久久久久久野外 | 欧洲第一区第二区第三区 | 69pao强力打造免费高速 | 艹的好爽 | 久久青青草原精品国产软件 | 欧洲美女人牲交一级毛片 | 美女扒下内裤让男人桶的图片 | 男女姓交大视频免费观看 | 免费一级欧美大片在线观看 | 草莓在线| 四虎影视免费 | 欧美午夜性春猛交bbb | 午夜一级毛片看看 | 国产精品福利在线观看秒播 | 亚洲精品一区二区久久这里 | 欧洲美女人牲交一级毛片 | 亚洲高清在线视频 | 成人福利视频网址 | 扒开双腿疯狂进出爽爽动态图 | 四虎海外影院 | 国产精品免费一级在线观看 | 高清国产激情视频在线观看 | 亚1洲二区三区四区免费 | 99精品国产在现线免费 | 国产福利兔女郎在线观看 | 午夜欧美精品 | 欧美国产精品久久 | 日韩一区二区三区精品 | 波多野结衣作品在线观看 |