濮阳杆衣贸易有限公司

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

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

熱門標(biāo)簽:外呼系統(tǒng)電銷專用 千呼電銷機(jī)器人價(jià)格 怎樣在地圖上標(biāo)注路線圖標(biāo) 百度地圖標(biāo)注不同路線 優(yōu)質(zhì)地圖標(biāo)注 武漢長(zhǎng)沙外呼系統(tǒng)方法和技巧 奧威地圖標(biāo)注多個(gè)地方 京華物流公司地圖標(biāo)注 智能語音外呼系統(tǒng)選哪家

問題:

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

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

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

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

解決方案:

  首先簡(jiǎn)單介紹一下基本的知識(shí)點(diǎn):

getdate()是獲取當(dāng)前日期;
dateadd可以對(duì)日期進(jìn)行增減,在這里用來對(duì)年份減少1【dateadd(year, -1, 日期字符串)】,也可以用來對(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è)問題對(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è)月,最后只截取年月日。

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

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

查詢統(tǒng)計(jì)時(shí)間節(jié)點(diǎn)開始到現(xiàn)在:select count(*) from 表 where 時(shí)間字段 >= @datePoint

腳本:

/*
 功能:獲取一年前日期
 作者:zhang502219048
 腳本來源: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編寫通用腳本實(shí)現(xiàn)獲取一年前日期的方法,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!

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

標(biāo)簽:七臺(tái)河 威海 來賓 宿州 銅仁 防疫戰(zhàn)設(shè) 益陽 天水

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《sql server編寫通用腳本實(shí)現(xiàn)獲取一年前日期的方法》,本文關(guān)鍵詞  sql,server,編寫,通用,腳本,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《sql server編寫通用腳本實(shí)現(xiàn)獲取一年前日期的方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于sql server編寫通用腳本實(shí)現(xiàn)獲取一年前日期的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    射洪县| 佛坪县| 榆社县| 平邑县| 漳平市| 沭阳县| 资溪县| 江城| 安丘市| 襄垣县| 新邵县| 仪征市| 三穗县| 汽车| 抚松县| 临泽县| 罗城| 汾阳市| 阜新市| 绥芬河市| 娄底市| 普兰县| 巴塘县| 从江县| 石渠县| 松原市| 沙湾县| 葵青区| 德江县| 永兴县| 高邮市| 乌兰县| 和硕县| 龙门县| 永年县| 光山县| 叶城县| 台中市| 呼图壁县| 左云县| 金门县|