轉自博客園: 1、獲取當前日期GetDate getdate()函數以datetime數據類型的格式返回當前SQLServer伺服器所在電腦的日期和時間。其語法格式為getdate()。返回值舍入到最近的秒小數部分,精度為.333秒資料庫十七偏移量不包含在內。 示例: 2、GetUTCDate 獲 ...
轉自博客園:
1、獲取當前日期GetDate
getdate()函數以datetime數據類型的格式返回當前SQLServer伺服器所在電腦的日期和時間。其語法格式為getdate()。返回值舍入到最近的秒小數部分,精度為.333秒資料庫十七偏移量不包含在內。
示例:
select getdate() --輸出 2013-03-09 15:16:00.570
2、GetUTCDate 獲取UTC時間值
select GETUTCDATE() -- 2013-06-18 08:02:53.253
這個獲取到的是UTC時間。
3、獲取年度信息YEAR
year函數以int數據類型的格式返回特定日期的年度信息。其語法格式為YEAR(date數據)。其中的date數據時一個可以解析為time、date、smalldatetime、datetime、datetime2或datetimeoffset值的表達式,列表達式、用戶定義的變數或字元串文字。
示例:
select year(getdate()) --輸出 2013
4、獲取月份信息MONTH
month函數以int數據類型的格式返回特定日期的月份信息。其語法格式為month(date數據)。其中的date數據時一個可以解析為time、date、smalldatetime、datetime、datetime2或datetimeoffset值的表達式,列表達式、用戶定義的變數或字元串文字。
示例:
select month(getdate()) --輸出 3
5、獲取天數信息day
day函數以int數據類型的格式返回特定日期的天數信息。其語法格式為day(date數據)。其中的date數據時一個可以解析為time、date、smalldatetime、datetime、datetime2或datetimeoffset值的表達式,列表達式、用戶定義的變數或字元串文字。
示例:
select day(getdate()) --輸出 9
6、獲取任意時間部分DatePart
datepart函數以int數據類型的格式返回某個日期時間數據的指定部分。
1、語法格式:
datepart( datepart , date數據 )
datepart:特定的要返回的數據的格式代碼。
date數據:一個可以解析為time、date、smalldatetime、datetime、datetime2或者datetimeoffset值的表達式、列表表達式、用戶定義的變數或字元串文字。
2、Datepart取值
Datepart部分的取值如下表所示:
說明 | 取值 |
返回年度信息 | Year、YYYY、YY |
返回月份信息 | Month、MM、M |
返回日期信息 | Day、DD、D |
返回周信息 | Week、WK、WW |
返回每周星期幾信息 | WeekDay、DW |
返回季度信息 | Quarter、QQ、Q |
返回一年中第幾天的信息 | DayOfYear、DY、Y |
返回小時信息 | Hour、HH |
返回分鐘信息 | Minute、MI、N |
返回秒信息 | Second、SS、SS |
返回毫秒信息 | MillSecond、MS |
7、獲取任意時間部分DateName
返回表示指定日期的指定日期部分的字元串。
SELECT DateName(Quarter,GetDate()) --輸出 2(6月)
示例:
select datepart(Quarter,getdate()) --輸出 1 現在是第幾季度
8、日期加法DATEADD
dateadd函數將某個日期加上一個特定的時間間隔值後返回datetime數據類型的值。
1、語法格式:
dateadd (datepart,numer,date數據)
numer:用於與detepart相加的值。如果指定了非整數值,則將捨棄該值的小數部分。
date數據:一個用於解析為time、date、smalldatetime、datetime、datetime2、或datetimeoffset值的表達式、列表達式、用戶定義的變數或字元串文字。
datepart:時間部分。上節。
示例:
select getdate() --輸出 2013-03-09 16:03:59.293 select dateadd(YYYY,10,getdate()) --加了十年 輸出2023-03-09 16:04:36.893
8、日期減法DATEDIFF
datediff函數將兩個特定的日期數據相減,得到的結果可以按照detepart指定的格式返回特定的數據。
1、語法格式:
datediff(datepart,startdate,enddate)
執行中將使用enddate減以startdate的值,如果startdate晚於enddate將返回負值。執行結果如果超出整數範圍將提示錯誤。
startdate:一個可以解析為time、date、smalldate、datetime、datetime2或datetimeoffset值的表達式、列表達式、用戶定義的變數或字元串文字。
enddate:一個可以解析為time、date、smalldate、datetime、datetime2或datetimeoffset值的表達式、列表達式、用戶定義的變數或字元串文字。
datepart:時間部分。
示例:
select datediff(YYYY,'2011-11-11','2012-12-12') --輸出1 年份相減之後的確是1 select datediff(day,'2011-11-11','2012-12-12') --輸出 397 兩個日期相差的天數
2013-3-13日補充,用此方法查詢當前的記錄:
select * from test where datediff(day,Rq,getdate()) = 0 --其中Rq為日期列,此行代碼的意思是什麼呢?getdate()減去Rq列的值為0,Rq列的值與今天相減,號數為0
9、SQLServer 2008中新增的日期時間型函數
1、獲取系統時間 SysDateTime
sysdatetime函數以datetime2(7)數據類型的格式返回當前系統的日期和時間。其語法格式為sysdatetime()。返回值有七個小數位,但只精確到10毫秒。資料庫偏移量未包含在內。
SELECT SYSDATETIME() --2013-06-17 22:17:59.0610211
2、獲取當前日期和時間 SysDateTimeOffset
sysdatetimeoffset函數以datetimeoffset(7)數據類型的格式返回當前系統的日期和時間。其語法格式為sysdatetimeoffset()。返回值有七個小數位,但只精確到10毫秒。資料庫時區偏移量包含在內。
SELECT sysdatetimeoffset() --2013-06-17 22:18:30.1788009 +08:00
3、獲取系統UTC時間 SysUTCDateTime
select SysUTCDateTime() -- 2013-06-18 08:09:17.8229505
10、Current_TimeStamp當前資料庫系統時間戳
返回當前資料庫系統時間戳,返回值的類型為 datetime,並且不含資料庫時區偏移量。 此值得自運行 SQL Server 實例的電腦的操作系統。等價於GetDate();
SELECT CURRENT_TIMESTAMP --2013-06-18 16:16:10.007
11、SWITCHOFFSET更改時間偏移量
SwitchOffset更改 DateTimeOffset 值的時區偏移量並保留 UTC 值。
SELECT SysDateTimeOffset() -- 2013-06-18 16:40:34.4322865 +08:00 SELECT SWITCHOFFSET (SysDateTimeOffset(), '+07:00') --2013-06-18 15:40:53.5403794 +07:00
12、TodateTimeOffset datetime2轉datetimeoffset
返回從 datetime2 表達式轉換而來的一個 datetimeoffset 值。
SELECT SysDateTimeOffset() -- 2013-06-18 16:40:34.4322865 +08:00 SELECT TodateTimeOffset(GetDate(),'+07:00') --2013-06-18 16:46:10.537 +07:00
留意到以上代碼是只更改時區,但是不更改時值。
SysDateTime 和 SysUTCDate 在秒小數部分精度上要比 GetDate 和 GetUTCDate 高。 SysDateTimeOffset 包含系統時區偏移量。 SysDateTime、SysUTCDate 和 SysDateTimeOffset 可分配給採用任意日期和時間類型的變數。
13、判斷是否為日期數據isDate
ISDATE函數可以驗證某個輸入值是否為有效的日期數據
1、語法結構:
ISDATE(expression)
2、返回值
若表達式為有效日期則返回 1 ,否則返回 0 。
示例:
select isdate('2012-12-12') -- 輸出1 select isdate('xxxx-12-12') -- 輸出0
http://technet.microsoft.com/zh-cn/library/ms186724.aspx#ModifyDateandTimeValues