sql server的基於日期的演算法集合

來源:互聯網
上載者:User

參考以下日期寫法
---求相差天數
select datediff(day,'2004-01-01',getdate())

 --1.一個月第一天的
SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)

 --2.本周的星期一
SELECT DATEADD(wk, DATEDIFF(wk,0,getdate()), 0)

 select dateadd(wk,datediff(wk,0,getdate()),6)
--3.一年的第一天
SELECT DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)

 --4.季度的第一天
SELECT DATEADD(qq, DATEDIFF(qq,0,getdate()), 0)

 --5.當天的半夜
SELECT DATEADD(dd, DATEDIFF(dd,0,getdate()), 0)

 --6.上個月的最後一天
SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))

 --7.去年的最後一天
SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))

 --8.本月的最後一天
SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0))

 --9.本年的最後一天
SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0))

 --10.本月的第一個星期一
select DATEADD(wk,DATEDIFF(wk,0,dateadd(dd,6-datepart(day,getdate()),getdate())), 0)

 --查詢本周註冊人數
select count(*) from [user] where datediff(week,create_day-1,getdate())=0

 --上周註冊人數
select count(*) from [user] where datediff(week,create_day-1,getdate())=1

 --本月註冊人數
select count(*) from [user]where datediff(month,create_day,getdate())=0

 --上月註冊人數
select count(*) from [user]
where datediff(month,create_day,getdate())=1

 

 --如果要效率,這樣寫查詢

 --查詢本周註冊人數
select count(*) from [user]where create_day>=dateadd(day,2-datepart(weekday,getdate()),convert(varchar,getdate(),112))
and create_day<dateadd(day,9-datepart(weekday,getdate()),convert(varchar,getdate(),112))

 --上周註冊人數
select count(*) from [user]where create_day>=dateadd(day,-5-datepart(weekday,getdate()),convert(varchar,getdate(),112))  and create_day<dateadd(day,2-datepart(weekday,getdate()),convert(varchar,getdate(),112))

 --本月註冊人數
select count(*) from [user]where create_day>=dateadd(day,1-day(getdate()),convert(varchar,getdate(),112))
and create_day<dateadd(month,1,dateadd(day,1-day(getdate()),convert(varchar,getdate(),112)))

 --上月註冊人數
select count(*) from [user] where create_day>=dateadd(month,-1,dateadd(day,1-day(getdate()),convert(varchar,getdate(),112)))
and create_day<dateadd(day,1-day(getdate()),convert(varchar,getdate(),112))

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.