sql语句中的日期处理
一.日期處理函數
1.日期增減函數
dateadd(datepart,number,dtae)
datepart:是規定應向日期的哪一部分返回新值的參數。下列是sql server支持的日期部分\縮寫及含義。
日期部分 縮寫 含義
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),<date>,+"1-1"
年的最後一天:
select convert(char(5),<date>,+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,<date>)*3-2,dateadd(month,-month(<date>),<date>)),120)+"1")
季度的最後一天(CASE判斷法):select convert(datetime,convert(char(8),dateadd(month,datepart(quarter,)*3,dateadd(month,-month(<date>),<date>)),120)+case when datepart(quarter,<date>) in(1,4) then \'31\' else\'30\' end)
季度的最後一天直接推算法:
dateadd(day,-1,convert(char(8),dateadd(month,datepart(quarter,<date>)*3+1,dateadd(month,-month(<date>),<date>)),120)+\'1\')
3.指定日期所在月份的第一天或最後一天
所在月份的第一天固定為1,只需要取出指定日期的年月部份再加上1就行了。對於月份的最後一天,它隨月份不同而不同,而且還會受平年與閏年的影響,不過當前月份的最後一天肯定是它下個月的1號減去1天,而下個月的1號很容易確定,所以只需要取得指定日期的下個月的1號的日期,然後減1天就行了。
在推算日期所在月份最後一天的處理中,一個容易犯的錯誤是:將指定日期減去當前日期的天數,得到指定日期的上一個月的最後一天。如使用這種處理方法,當指定日期上個月的天數比指定日期把在月份的天數多時,不會出現問題。否則就會少計算天數。
月的第一天:
select convert(datetime,convert(char(8),<date>,120)+\'1\')
月的最後一天:
select dateadd(day,-1,convert(char(8),dateadd(month,1,<date>),<date>),120)+\'1\')
月的最後一天(容易使用的錯誤方法):
select dateadd(month,1,dateadd(day,-day(<date>,<date>))
4.計算年齡
要計算准確的年齡,可以這樣考慮,將出生日期的月日部分與當前的日期的月日部分做比較,如果是大於的情況,則表明今年的生日還沒有到,應該將當前日期減去出生日期的結果再減1年,否則直接是現兩個日期年份相減。但這做忽略了一個特殊的日期:閏年的2月29號,這個日期出的人,在平年的時候,應該是2月28號生日,按上面的處理方法恰好是錯過了一天,所以完善的解決方法是,將出生日期的年份增加到與當前日期相同,然後再與當前日期比較,如果大於,則年齡為當前日期減去出生日期的結果再減1年,否則是兩個日期直接相減。
處理代碼如下(其中,<birthday>是出生日期,<current_date>是當前日期)。
select datediff(year,<birthday>,<current_date>)-case when dateadd(year,datediff(year,<birthday>,<current_date>,<birthday>)><current_date> 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. 本月的第一天
SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)
2. 本月的最后一天
SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0))
3.上个月的第一天
select dateadd(m,-1, DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))
4. 上个月的最后一天
SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))
5. 本周的星期一
SELECT DATEADD(wk, DATEDIFF(wk,0,getdate()), 0)
6.本周的周日
select dateadd(d,+6 ,DATEADD(wk, DATEDIFF(wk,0,getdate()), 0) )
7.上周的星期一
select dateadd(d,-7 ,DATEADD(wk, DATEDIFF(wk,0,getdate()), 0) )
8.上周的周日
select dateadd(d,-1 ,DATEADD(wk, DATEDIFF(wk,0,getdate()), 0) )
9. 一年的第一天
SELECT DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)
10. 季度的第一天
SELECT DATEADD(qq, DATEDIFF(qq,0,getdate()), 0)
11. 去年的最后一天
SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))
12. 本月的第一个星期一
select DATEADD(wk, DATEDIFF(wk,0,dateadd(dd,6-datepart(day,getdate)),getdate))),0)
13. 本年的最后一天
SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0))。
Sql Server中的日期与时间函数
1. 当前系统日期、时间
select getdate()