標籤:style blog color ar sp for 資料 div on
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 SmalldatetimeSelect @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 EndSelect @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()) --WednesdaySelect Datepart(weekday, Getdate()) --返回3Select @@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;GoDeclare @datevar Datetime;Set @datevar = ‘1998/31/12‘;Select @datevar As DateVar;Go-- Set date format to year, month, day.Set Dateformat ymd;GoDeclare @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 日 |
SQL Server 日期和時間函數