SQL Server 日期和时间函数

1、常用日期方法(下面的GetDate() = ‘2006-11-08 13:37:56.233‘)

(1)DateName( datepart ,date )

   返回表示指定日期的指定日期部分的字符串。Datepart详见下面的列表.

Select Datename(Day, Getdate()) --返回 8

 

(2)DATEPART ( datepart , date )

    返回表示指定日期的指定日期部分的整数。

Select Datepart(Year, Getdate()) --返回2006

 

(3)DATEADD (datepart , number, date )

    返回给指定日期加上一个时间间隔后的新datetime 值。

Select Dateadd(week, 1, Getdate()) --当前日期加一周后的日期

 

(4)DATEDIFF ( datepart , startdate , enddate )

返回跨两个指定日期的日期边界数和时间边界数。

Select Datediff(Month, 2006-10-11, 2006-11-01)  --返回1

 

(5)DAY ( date )

返回一个整数,表示指定日期的天datepart 部分。

Select Day(Getdate()) --日期为:2014-11-08 08:56:45.903,返回8

 

(6)GETDATE()

以datetime 值的SQL Server 2005 标准内部格式返回当前系统日期和时间。

Select Getdate() --返回2006-11-08 13:37:56.2

 

(7)MONTH ( date )

返回表示指定日期的“月”部分的整数。

Select Month(Getdate()) --返回

 

(8)YEAR ( date )

返回表示指定日期的“年”部分的整数。

Select Year(Getdate()) --返回2006


2、取特定日期

(1)获得当前日期是星期几

Select Datename(weekday, Getdate()) --Wednesday

 

(2)计算哪一天是本周的星期一

Select Dateadd( week, Datediff(week, 1900-01-01, Getdate()), 1900-01-01 )  --返回2006-11-06 00:00:00.000
--
Select Dateadd(week, Datediff(week, 0, Getdate()), 0)

 

(3)当前季度的第一天

Select Dateadd(quarter, Datediff(quarter, 0, Getdate()), 0)  --返回2006-10-01 00:00:00.0

 

(4)如何取得某个月的天数

Select Day( Dateadd(ms, -3, Dateadd(mm, Datediff(m, 0, 2006-02-03) + 1, 0))) --返回28

 

(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)) --返回92

 


(6)获得年月日(yyyy-MM-dd)

Select Convert(Varchar(10), Getdate(), 120) --返回2006-11-

 

3、其它

(1)--下面的示例将日期指定为数字。数据库引擎将0 解释为1900 年1 月1 日。

Select Month(0), Day(0), Year(0)
--下面两句是等效的
Select Datename(WEEKDAY, 0)
Select Datename(WEEKDAY, 1900-01-01)

 


(2)SET DATEFIRST { number | @number_var }

将一周的第一天设置为从1 到7 的一个数字。

Set Datefirst 1 --表示一周的第一天是“星期一"
Select Datename(WEEKDAY, Getdate())  --Wednesday
Select Datepart(weekday, Getdate()) --返回3
Select @@DATEFIRST  --查看当前设置情况


(3)SET DATEFORMAT { format | @format_var }

设置用于输入datetime 或smalldatetime 数据的日期部分(月/日/年)的顺序。
...有效参数包括mdy、dmy、ymd、ydm、myd 和dym。
...该设置仅用在将字符串转换为日期值时的解释中。它不影响日期值的显示。
...SET DATEFORMAT 的设置是在执行或运行时设置,而不是在分析时设置。
...SET DATEFORMAT 将覆盖SET LANGUAGE 的隐式日期格式设置。
下面是例子:

-- Set date format to year, day, month.
Set Dateformat ydm;
Go
Declare @datevar Datetime;
Set @datevar = 1998/31/12;
Select @datevar As DateVar;
Go
-- Set date format to year, month, day.
Set Dateformat ymd;
Go
Declare @datevar Datetime;
Set @datevar = 1998/12/31;
Select @datevar As DateVar;
Go

 


(4)日期部分的列表

日期部分

缩写

year

yy, yyyy

quarter

qq, q

month

mm, m

dayofyear

dy, y

day

dd, d

week

wk, ww

weekday

dw

hour

hh

minute

mi, n

second

ss, s

millisecond

ms

 

 

数据类型

范围

精确度

datetime

1753 年 1 月 1 日到 9999 年 12 月 31 日

3.33 毫秒

smalldatetime

1900 年 1 月 1 日到 2079 年 6 月 6 日

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。