在线观看 国产-在线高清一级欧美精品-在线高清国产-在线福利视频-久久观看视频-久久观看

下載吧 - 綠色安全的游戲和軟件下載中心

軟件下載吧

當(dāng)前位置:軟件下載吧 > 數(shù)據(jù)庫(kù) > MS_SQL > SQL開(kāi)發(fā)知識(shí):sql server編寫(xiě)通用腳本實(shí)現(xiàn)獲取一年前日期的方法

SQL開(kāi)發(fā)知識(shí):sql server編寫(xiě)通用腳本實(shí)現(xiàn)獲取一年前日期的方法

時(shí)間:2024-03-11 15:08作者:下載吧人氣:28

問(wèn)題:

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

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

  以上這四種情況的具體查詢場(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ā)腳本的話,又需要重新進(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))】。  

然后就是針對(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è)月,最后只截取年月日。

  最后就可以直接在查詢腳本條件中使用這個(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)開(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

標(biāo)簽MSSQL,SQLServer,技術(shù)文檔,數(shù)據(jù)庫(kù),SQLSERVER

相關(guān)下載

查看所有評(píng)論+

網(wǎng)友評(píng)論

網(wǎng)友
您的評(píng)論需要經(jīng)過(guò)審核才能顯示

熱門(mén)閱覽

最新排行

公眾號(hào)

主站蜘蛛池模板: 国产一区二区精品久久 | 爱婷婷网站在线观看 | 性色爽爱性色爽爱网站 | 日韩欧美在线播放视频 | 羞羞首页登录界面入口免费 | 伊人天堂网 | 中文视频在线观看 | 男女免费视频网站 | 91欧美一区二区三区综合在线 | 亚洲人免费 | 午夜小视频免费观看 | 中文字幕乱码视频32 | 久久久久久极精品久久久 | 免费电视剧在哪里看 | 久久国产精品高清一区二区三区 | 免费高清a级毛片在线播放 美女隐私羞羞视频在线观看 | 四虎永久在线免费观看 | 羞羞视频在线观看免费 | 9色视频在线观看 | 四虎地址8848 | 自拍偷拍欧美 | 一本久道热中字伊人 | 国产免费小视频在线观看 | 日本波多野结衣在线观看 | 亚洲电影免费在线看精品国产 | 在线99视频 | 久久国产经典视频 | 在线视频aa| 国产精品毛片一区二区三区 | 亚洲欧美色一区二区三区 | 亚洲毛片免费看 | 精品久久一区 | 亚洲一区二区欧美 | 五月综合激情视频在线观看 | 麻豆国产 | 日本人免费xxx在线视频 | 一级片在线免费看 | a级高清观看视频在线看 | 亚洲国产精品乱码一区二区三区 | 丁香激情六月天 | 亚洲综合色丁香婷婷六月图片 |