sql server編寫(xiě)通用腳本實(shí)現(xiàn)獲取一年前日期的方法
問(wèn)題:
在數(shù)據(jù)庫(kù)編程開(kāi)發(fā)中,有時(shí)需要獲取一年前的日期,以便以此為時(shí)間的分界點(diǎn),查詢(xún)其前后對(duì)應(yīng)的數(shù)據(jù)量。例如:
1. 想查詢(xún)截止到一年前當(dāng)天0點(diǎn)之前的數(shù)據(jù)量,以及一年前當(dāng)天0點(diǎn)開(kāi)始到現(xiàn)在的數(shù)據(jù)量。
2. 想查詢(xún)截止到一年前當(dāng)天24點(diǎn)之前的數(shù)據(jù)量,以及一年前當(dāng)天24點(diǎn)開(kāi)始到現(xiàn)在的數(shù)據(jù)量。
3. 想查詢(xún)截止到一年前當(dāng)月1日0點(diǎn)之前的數(shù)據(jù)量,以及一年前當(dāng)月1日0點(diǎn)開(kāi)始到現(xiàn)在的數(shù)據(jù)量。
4. 想查詢(xún)截止到一年前當(dāng)月最后一天24點(diǎn)之前的數(shù)據(jù)量,以及一年前當(dāng)月最后一天24點(diǎn)開(kāi)始到現(xiàn)在的數(shù)據(jù)量。
以上這四種情況的具體查詢(xún)場(chǎng)景,有archive數(shù)據(jù)腳本開(kāi)發(fā)之前對(duì)數(shù)據(jù)庫(kù)數(shù)據(jù)量的分布情況進(jìn)行統(tǒng)計(jì)等,也有根據(jù)當(dāng)前日期動(dòng)態(tài)計(jì)算一年來(lái)的增量增幅情況等。
如果每次接到這樣的需求需要獲取一年前日期,然后每次重新思考怎么去實(shí)現(xiàn)肯定是不明智的,或者說(shuō)公司內(nèi)已經(jīng)有人寫(xiě)了腳本實(shí)現(xiàn),但其他同事遇到相同的問(wèn)題,又重新構(gòu)思一次,這樣就比較浪費(fèi)時(shí)間和精力,耗在這個(gè)細(xì)節(jié)上一些精力,有點(diǎn)像要做飯可是沒(méi)有米就要先去買(mǎi)米的感覺(jué),而且容易造成不同人寫(xiě)的腳本不統(tǒng)一,不利于代碼規(guī)范化標(biāo)準(zhǔn)化的原則,不同的人跟進(jìn)的時(shí)候還要去想想之前的人寫(xiě)的是什么邏輯。而且重新開(kāi)發(fā)腳本的話(huà),又需要重新進(jìn)行自測(cè),不利于提高工作效率。
解決方案:
首先簡(jiǎn)單介紹一下基本的知識(shí)點(diǎn):
getdate()是獲取當(dāng)前日期;
dateadd可以對(duì)日期進(jìn)行增減,在這里用來(lái)對(duì)年份減少1【dateadd(year, -1, 日期字符串)】,也可以用來(lái)對(duì)月份增加1【dateadd(month, 1, 日期字符串)】;
convert可以對(duì)日期進(jìn)行字符串截取轉(zhuǎn)換操作,在這里可以只截取形如2019-07-17的年月日【convert(varchar(10), 日期字符串, 120))】,也可以只截取形如2019-07的年月部分【convert(varchar(7), 日期字符串, 120))】?! ?br />
然后就是針對(duì)上面4個(gè)問(wèn)題對(duì)應(yīng)的4個(gè)解決方法:
1. 最簡(jiǎn)單,對(duì)當(dāng)前日期進(jìn)行減少1年的運(yùn)算,然后只截取年月日。
2. 先對(duì)當(dāng)前日期進(jìn)行增加1天的運(yùn)算,然后再減少1年,最后只截取年月日。
3. 先對(duì)當(dāng)前日期進(jìn)行截取年月操作,然后再指定為當(dāng)月01日,再減少1年,最后只截取年月日。
4. 先對(duì)當(dāng)前日期進(jìn)行截取年月操作,然后再指定為當(dāng)月01日,再減少1年,并加上1個(gè)月,最后只截取年月日。
最后就可以直接在查詢(xún)腳本條件中使用這個(gè)時(shí)間節(jié)點(diǎn):
查詢(xún)統(tǒng)計(jì)時(shí)間節(jié)點(diǎn)之前:select count(*) from 表 where 時(shí)間字段 < @datePoint
查詢(xún)統(tǒng)計(jì)時(shí)間節(jié)點(diǎn)開(kāi)始到現(xiàn)在:select count(*) from 表 where 時(shí)間字段 >= @datePoint
腳本:
/* 功能:獲取一年前日期 作者:zhang502219048 腳本來(lái)源:https://www.cnblogs.com/zhang502219048/p/11198789.html */ --1.截止到一年前當(dāng)天0點(diǎn) declare @datePoint datetime = convert(varchar(10), dateadd(year, -1, getdate()), 120) select @datePoint as DatePoint go --2.截止到一年前當(dāng)天24點(diǎn) declare @datePoint datetime = convert(varchar(10), dateadd(year, -1, dateadd(day, 1, getdate())), 120) select @datePoint as DatePoint go --3.截止到一年前當(dāng)月1日0點(diǎn) declare @datePoint datetime = convert(varchar(10), dateadd(year, -1, convert(varchar(7), getdate(), 120) + '-01'), 120) select @datePoint as DatePoint go --4.截止到一年前當(dāng)月最后一天24點(diǎn) declare @datePoint datetime = convert(varchar(10), dateadd(month, 1, dateadd(year, -1, convert(varchar(7), getdate(), 120) + '-01')), 120) select @datePoint as DatePoint go
腳本運(yùn)行結(jié)果:
總結(jié)
以上所述是小編給大家介紹的sql server編寫(xiě)通用腳本實(shí)現(xiàn)獲取一年前日期的方法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)我們網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
上一篇:行轉(zhuǎn)列之SQL SERVER PIVOT與用法詳解
欄 目:MsSql
下一篇:SQL Server利用sp
本文標(biāo)題:sql server編寫(xiě)通用腳本實(shí)現(xiàn)獲取一年前日期的方法
本文地址:http://mengdiqiu.com.cn/a1/MsSql/10308.html
您可能感興趣的文章
- 01-10SQLServer存儲(chǔ)過(guò)程實(shí)現(xiàn)單條件分頁(yè)
- 01-10SQL Server 2012降級(jí)至2008R2的方法
- 01-10SQLServer中防止并發(fā)插入重復(fù)數(shù)據(jù)的方法詳解
- 01-10SQL Server數(shù)據(jù)庫(kù)定時(shí)自動(dòng)備份
- 01-10SQL Server性能調(diào)優(yōu)之緩存
- 01-10實(shí)現(xiàn)SQL Server 原生數(shù)據(jù)從XML生成JSON數(shù)據(jù)的實(shí)例代碼
- 01-10Sql Server 死鎖的監(jiān)控分析解決思路
- 01-10SqlServer 在事務(wù)中獲得自增ID的實(shí)例代碼
- 01-10SqlServer快速檢索某個(gè)字段在哪些存儲(chǔ)過(guò)程中(sql 語(yǔ)句)
- 01-10SQLServer性能優(yōu)化--間接實(shí)現(xiàn)函數(shù)索引或者Hash索引


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 01-10SQLServer存儲(chǔ)過(guò)程實(shí)現(xiàn)單條件分頁(yè)
- 01-10SQLServer中防止并發(fā)插入重復(fù)數(shù)據(jù)的方
- 01-10SQL Server 2012降級(jí)至2008R2的方法
- 01-10SQL Server性能調(diào)優(yōu)之緩存
- 01-10SQL Server數(shù)據(jù)庫(kù)定時(shí)自動(dòng)備份
- 01-10Sql Server 死鎖的監(jiān)控分析解決思路
- 01-10實(shí)現(xiàn)SQL Server 原生數(shù)據(jù)從XML生成JSON數(shù)
- 01-10SqlServer快速檢索某個(gè)字段在哪些存儲(chǔ)
- 01-10SqlServer 在事務(wù)中獲得自增ID的實(shí)例代
- 01-10SQLServer性能優(yōu)化--間接實(shí)現(xiàn)函數(shù)索引或
隨機(jī)閱讀
- 01-11Mac OSX 打開(kāi)原生自帶讀寫(xiě)NTFS功能(圖文
- 01-10delphi制作wav文件的方法
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 01-10C#中split用法實(shí)例總結(jié)
- 04-02jquery與jsp,用jquery
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改