SQL日期處理方法

2021-04-27 04:50:32 字數 4503 閱讀 3448

一.日期處理函式

1.日期增減函式

dateadd(datepart,number,dtae)

datepart:是規定應向日期的哪一部分返回新值的引數。下列是

sqlserver支援的日期部分/縮寫及含義。

日期部分     縮寫                   含義

year       yy,yyyy                年份

quarter                 qq,q       季度

month                  mm,m       月份

dayofyear              dy,y       日

day                      dd,d                   

week                    wk,ww     星期

hour                     hh        小時

minute                  mi,n                   分鐘

second                 ss,s       秒

millisecond             ms       毫秒

number:是用來增加datepart的值。正數表示增加,負數表示減少,如果指定的是非整數值,則忽略此值的小

數部分,不做四捨五入處理,例如,dateadd(day,1.7,date),表示date增加1天。

date:是返回datetime或smalldatetime值或日期格式字串的表示式。

2.日期差值計算函式

datediff(datepart,startdate,enddate)

datepart:規定了應在日期的哪一部分計算差值。

startdate:計算的開始日期。

enddate:計算的終止日期。

set datefirst函式是設定一周的第一天是星期幾。

二.日期推算處理

1.指定日期該年的第一天或最後一天

對於年的第一天或最後一天,它們的月日資訊(第一天為1月1日、最後一天為12月31日)都是固定的,反以只需取

出指定日期的年份,再加上月份和天(字串相加)就可以了。

年的第一天:

select convert(char(5),,+"1-1"

年的最後一天:

select convert(char(5),,+12-31"

2.指定日期所在季度的第一天或最後一天

首先分析月份,可以用datepart(quarter,date)函式取得指定日期所在的季度,乙個季度有3個月份,所以datepart(quarter,date)*3就是該季度的最後乙個月的月份,再減去2就是該季度最早乙個月的月份。接下來要把指定日期的月份轉換到這個推算出的月份,可以把指定日期減去指定日期的月份數,得到指定日期所在年的上一年的最後乙個月,然後再加上由季度推算出來的月份數。

再分析天的處理,對於第一天,可以直接取得換算後的年月資訊字串,再用字串相加上天的資訊,轉換回日期型就是指定日期所在季度的第一天;對於最後一天,由於一年就4個季度,對就的每季度的最後乙個月份分別是3、6、9、12這4個月,它們的最後一天是確定的,分別是31、30、30、31,所以完全可以用case來判斷處理。另一種方法用所在季度最後乙個月的下乙個月的第一天減1天。

季度的第一天:

select conver(datetime,convert(char(8),dateadd(month,datepart(quarter,)*3-2,dateadd(month,-month(),)),120)+"1")

季度的最後一天(case判斷法):select convert(datetime,convert(char(8),dateadd(month,datepart(quarter,)*3,dateadd(month,-month(),)),120)+case when datepart(quarter,) in(1,4) then '31' else'30' end)

季度的最後一天直接推算法:

dateadd(day,-1,convert(char(8),dateadd(month,datepart(quarter,)*3+1,dateadd(month,-month(),)),120)+'1')

3.指定日期所在月份的第一天或最後一天

所在月份的第一天固定為1,只需要取出指定日期的年月部份再加上1就行了。對於月份的最後一天,它隨月份不同而不同,而且還會受平年與閏年的影響,不過當前月份的最後一天肯定是它下個月的1號減去1天,而下個月的1號很容易確定,所以只需要取得指定日期的下個月的1號的日期,然後減1天就行了。

在推算日期所在月份最後一天的處理中,乙個容易犯的錯誤是:將指定日期減去當前日期的天數,得到指定日期的上乙個月的最後一天。如使用這種處理方法,當指定日期上個月的天數比指定日期把在月份的天數多時,不會出現問題。否則就會少計算天數。

月的第一天:

select convert(datetime,convert(char(8),,120)+'1')

月的最後一天:

select dateadd(day,-1,convert(char(8),dateadd(month,1,),),120)+'1')

月的最後一天(容易使用的錯誤方法):

select dateadd(month,1,dateadd(day,-day(,))

4.計算年齡

要計算準確的年齡,可以這樣考慮,將出生日期的月日部分與當前的日期的月日部分做比較,如果是大於的情況,則表明今年的生日還沒有到,應該將當前日期減去出生日期的結果再減1年,否則直接是現兩個日期年份相減。但這做忽略了乙個特殊的日期:閏年的2月29號,這個日期出的人,在平年的時候,應該是2月28號生日,按上面的處理方法恰好是錯過了一天,所以完善的解決方法是,將出生日期的年份增加到與當前日期相同,然後再與當前日期比較,如果大於,則年齡為當前日期減去出生日期的結果再減1年,否則是兩個日期直接相減。

處理程式碼如下(其中,<birthday>是出生日期,是當前日期)。

select datediff(year,,)-case when dateadd(year,datediff(year,,,)>then 1 else 0 end

日期處理方法

1)去掉時分秒

declare @ datetime

set @ = getdate() --'2003-7-1 10:00:00'

select @,dateadd(day, datediff(day,0,@), 0)

2)顯示星期幾

select datename(weekday,getdate())

3)如何取得某個月的天數

declare @m int

set @m=2 --月份

select datediff(day,'2003-'+cast(@m as varchar)+'-15' ,'2003-'+cast(@m+1 as varchar)+'-15')

另外,取得本月天數

select datediff(day,cast(month(getdate()) as varchar)+'-'+cast(month(getdate()) as varchar)+'-15' ,cast(month(getdate()) as varchar)+'-'+cast(month(getdate())+1 as varchar)+'-15')

或者使用計算本月的最後一天的指令碼,然後用day函式區最後一天

select day(dateadd(ms,-3,dateadd(mm, datediff(m,0,getdate())+1, 0)))

4)判斷是否閏年:

select case day(dateadd(mm, 2, dateadd(ms,-3,dateadd(yy, datediff(yy,0,getdate()), 0)))) when 28 then '平年' else '閏年' end

或者 select case datediff(day,datename(year,getdate())+'-02-01',dateadd(mm,1,datename(year,getdate())+'-02-01'))

when 28 then '平年' else '閏年' end

5)乙個季度多少天

declare @m tinyint,@time smalldatetime

select @m=month(getdate())

select @m=case when @m between 1 and 3 then 1

when @m between 4 and 6 then 4

when @m between 7 and 9 then 7

else 10 end

select @time=datename(year,getdate())+'-'+convert(varchar(10),@m)+'-01'

select datediff(day,@time,dateadd(mm,3,@time))

sql日期處理

1 日期格式化處理 declare dt datetime set dt getdate 1 短日期格式 yyyy m d select replace convert varchar 10 dt,120 n 0 2 長日期格式 yyyy年mm月dd日 a.方法1 select stuff stuf...

SQL日期處理 短日期

1 獲取當前日期 getdate 2 短日期 convert varchar 10 getdate 23 返回 2010 04 06 3 dateadd day,1,getdate 當前日期加1 日期部分 縮寫yearyy,yyyy quarterqq,q monthmm,m dayofyeardy...

日期處理方法

對date的擴充套件,將 date 轉化為指定格式的string 月 m 日 d 12小時 h 24小時 h 分 m 秒 s 周 e 季度 q 可以用 1 2 個佔位符 年 y 可以用 1 4 個佔位符,毫秒 s 只能用 1 個佔位符 是 1 3 位的數字 eg new date pattern y...