SQL Server日期時間函數

 日期時間函數

  一、獲取當前日期GetDate數據庫

   getdate()函數以datetime數據類型的格式返回當前SQLServer服務器所在計算機的日期和時間。其語法格式爲getdate()。返回值舍入到最近的秒小數部分,精度爲.333秒數據庫十七偏移量不包含在內。express

     示例:服務器

  select getdate() --輸出 2013-03-09 15:16:00.570

  二、GetUTCDate 獲取UTC時間值函數

  select GETUTCDATE() -- 2013-06-18 08:02:53.253

  這個獲取到的是UTC時間。ui

  三、獲取年度信息YEAR  spa

   year函數以int數據類型的格式返回特定日期的年度信息。其語法格式爲YEAR(date數據)。其中的date數據時一個能夠解析爲time、date、smalldatetime、datetime、datetime2或datetimeoffset值的表達式,列表達式、用戶定義的變量或字符串文字。操作系統

   示例:code

  select year(getdate()) --輸出 2013

  四、獲取月份信息MONTHblog

   month函數以int數據類型的格式返回特定日期的月份信息。其語法格式爲month(date數據)。其中的date數據時一個能夠解析爲time、date、smalldatetime、datetime、datetime2或datetimeoffset值的表達式,列表達式、用戶定義的變量或字符串文字。ci

    示例:

  select month(getdate()) --輸出 3

  五、獲取天數信息day

   day函數以int數據類型的格式返回特定日期的天數信息。其語法格式爲day(date數據)。其中的date數據時一個能夠解析爲time、date、smalldatetime、datetime、datetime2或datetimeoffset值的表達式,列表達式、用戶定義的變量或字符串文字。

    示例:

  select day(getdate()) --輸出 9

  六、獲取任意時間部分DatePart

   datepart函數以int數據類型的格式返回某個日期時間數據的指定部分。

   一、語法格式:

  datepart( datepart , date數據 )

   datepart:特定的要返回的數據的格式代碼。

  date數據:一個能夠解析爲time、date、smalldatetime、datetime、datetime2或者datetimeoffset值的表達式、列表表達式、用戶定義的變量或字符串文字。

   二、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

   七、獲取任意時間部分DateName

    返回表示指定日期的指定日期部分的字符串。

  SELECT DateName(Quarter,GetDate()) --輸出 2(6月)

  示例:

  select datepart(Quarter,getdate()) --輸出 1 如今是第幾季度

  八、日期加法DATEADD

    dateadd函數將某個日期加上一個特定的時間間隔值後返回datetime數據類型的值。

    一、語法格式:

  dateadd (datepart,numer,date數據)

    numer:用於與detepart相加的值。若是指定了非整數值,則將捨棄該值的小數部分。

    date數據:一個用於解析爲time、date、smalldatetime、datetime、datetime二、或datetimeoffset值的表達式、列表達式、用戶定義的變量或字符串文字。

    datepart:時間部分。上節。

    示例:

  select getdate()    --輸出 2013-03-09 16:03:59.293
  select dateadd(YYYY,10,getdate())    --加了十年    輸出2023-03-09 16:04:36.893        

  八、日期減法DATEDIFF

    datediff函數將兩個特定的日期數據相減,獲得的結果能夠按照detepart指定的格式返回特定的數據。

    一、語法格式:

  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  

  九、SQLServer 2008中新增的日期時間型函數

    一、獲取系統時間 SysDateTime

    sysdatetime函數以datetime2(7)數據類型的格式返回當前系統的日期和時間。其語法格式爲sysdatetime()。返回值有七個小數位,但只精確到10毫秒。數據庫偏移量未包含在內。

  SELECT SYSDATETIME()  --2013-06-17 22:17:59.0610211

    二、獲取當前日期和時間 SysDateTimeOffset

    sysdatetimeoffset函數以datetimeoffset(7)數據類型的格式返回當前系統的日期和時間。其語法格式爲sysdatetimeoffset()。返回值有七個小數位,但只精確到10毫秒。數據庫時區偏移量包含在內。

  SELECT sysdatetimeoffset()  --2013-06-17 22:18:30.1788009 +08:00

    三、獲取系統UTC時間 SysUTCDateTime

  select SysUTCDateTime() -- 2013-06-18 08:09:17.8229505

  十、Current_TimeStamp當前數據庫系統時間戳

  返回當前數據庫系統時間戳,返回值的類型爲 datetime,而且不含數據庫時區偏移量。 此值得自運行 SQL Server 實例的計算機的操做系統。等價於GetDate();

  SELECT CURRENT_TIMESTAMP --2013-06-18 16:16:10.007

  十一、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

  十二、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 可分配給採用任意日期和時間類型的變量。

  1三、判斷是否爲日期數據isDate

    ISDATE函數能夠驗證某個輸入值是否爲有效的日期數據

    一、語法結構:

  ISDATE(expression)

    二、返回值

     若表達式爲有效日期則返回 1 ,不然返回 0 。

    示例:

    select isdate('2012-12-12')    -- 輸出1
    select isdate('xxxx-12-12')  -- 輸出0

 http://technet.microsoft.com/zh-cn/library/ms186724.aspx#ModifyDateandTimeValues

相關文章
相關標籤/搜索