1. 程式人生 > >SQL Server日期時間函式

SQL Server日期時間函式

日期時間函式

     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        	

    9、日期減法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  	

    10、SQLServer 2008中新增的日期時間型函式

     1、獲取系統時間 SysDateTime

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

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

     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

    11、Current_TimeStamp當前資料庫系統時間戳

  返回當前資料庫系統時間戳,返回值的型別為 datetime,並且不含資料庫時區偏移量。 此值得自執行 SQL Server 例項的計算機的作業系統。等價於GetDate();

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

    12、SWITCHOFFSET更改時間偏移量

      SwitchOffset更改 DateTimeOffset 值的時區偏移量並保留 UTC 值。

    13、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 可分配給採用任意日期和時間型別的變數。

    14、判斷是否為日期資料isDate

      ISDATE函式可以驗證某個輸入值是否為有效的日期資料

      1、語法結構:

      ISDATE(expression)	

      2、返回值

    若表示式為有效日期則返回 1 ,否則返回 0 。

    示例:

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

  

相關推薦

SQL Server日期時間函式

日期時間函式      1、獲取當前日期GetDate           getdate()函式以datetime資料型別的格式返回當前SQLServer伺服器所在計算機的日期和時間。其語法格式為getdate()。返回值舍入到最近的秒小數部 分,精度為.333秒資料庫十

sql server 日期時間比較函式

DATEDIFF 返回跨兩個指定日期的日期和時間邊界數。 語法 DATEDIFF ( datepart , startdate , enddate ) 引數 datepart 是規定了應在日期的哪一部分計算差額的引數。下表列出了 Microsoft® SQL Server™ 識別的日期部分和縮寫。 日期部分

SQL Server日期時間格式轉換字符串詳解

dateadd access strong 分鐘 char 時間 詳解 var net 1、日期時間轉字符串 Select CONVERT(varchar(100), GETDATE(), 0): 05 16 2006 10:57AMSelect CONVERT(

Sql Server 日期格式化函式

Sql Server 中一個非常強大的日期格式化函式 Select CONVERT(varchar(100), GETDATE(), 0): 05 16 2006 10:57AM Select CONVERT(varchar(100), GETDATE(), 1): 05/16/06 Select

sql server日期函式 怎麼查詢日期時間

有時候在開發的時候可能需要某個時間欄位的某個特定的日期,比如說我們student表中有一個欄位是 comeyear (入學日期) 好的,這個是一個datatime型別的,如2012-9-1 12:12:15 我們這個學生是12年9月一號入學的,讓我們看一下

SQL日期時間函式(2)

我們把這個語句分開來看看它是如何工作的。最核心的函式是getdate(),大部分人都知道這個是返回當前的日期和時間的函式。下一個執行的函式DATEDIFF(mm,0,getdate())是計算當前日期和“1900-01-01 00:00:00.000”這個日期之間的月數。記住:時期和時間變數和毫秒一樣是從“1

SQL Server日期函式獲得一個月中天數的方案

此文主要向大家描述的是SQL Server日期函式之獲得一個月中的實際天數的正確操作步驟,在實際草組中如果你想獲得一個月的天數其主要操作技巧是:首先到得一個月最後一天的日期,然後通過 SQL Server 日期函式 day() 取得日期中的“天” 部分。 獲得 2008 年 2 月份的天數: selec

sql server 日期比較大小的方法及相關函式

在用sql server 開發相關專案時我們經常要用到日期的相關操作,這裡彙總了一些常用的方法及函式: 下面的表格列出了 SQL Server 中最重要的內建日期函式: 函式 描述 GETDATE() 返回當前日期和時間 DATEPART() 返

深入SQL Server 日期時間的內部儲存

在SQL Server的內部儲存中,日期和時間不是以字串的形式儲存的,而是使用整數來儲存的。使用特定的格式來區分日期部分和時間部分的偏移量,並通過基準日期和基準時間來還原真實的資料。 一,DateTime的內部儲存 SQL Server儲存引擎把DateTime型別儲存為2個int32型別,共8個位元組,

SQL Server 本地時間和UTC時間的相互轉換

get gpo () localdate lda code date() post nbsp SET @UTCDate = DATEADD(hour, DATEDIFF(hour,GETDATE(),GETUTCDATE()), @LocalDate) SET @Local

SQL Server 生成時間序列

WITH DateSequence AS ( SELECT CONVERT(DATETIME,'20150101') AS DateNum UNION ALL SELECT DateNum+1 FROM DateSequence WHERE Da

DB2常用函式三:日期時間函式

DATE函式  語法:DATE(ARG)  DATE函式返回一個日期、時間戳、日期字串、時間戳字串中的日期。 Sql程式碼 eg:       SEL

mysql 常用日期,時間函式

MySQL常用時間函式   1.1 獲得當前日期+時間(date + time)函式:now()   1.2 獲得當前日期+時間(date + time)函式:sysdate() sysdate() 日期時間函式跟 now() 類似,不同之處在於:now()

Sql Server日期查詢-SQL查詢今天、昨天、7天內、30天

注: SQL查詢某一段的資料用的比較多,本人記性差,就只有轉載一下辣! 今天的所有資料:select * from 表名 where DateDiff(dd,datetime型別欄位,getdate())=0 昨天的所有資料:select * from 表名 where DateDiff(dd,d

日期時間函式

日期時間型別的資料也是經常用到的,比如員工出生日期、結賬日期、入庫日期等等,而且經常需要對這些資料進行處理,比如檢索所有超過保質期的商品、將結賬日期向後延遲3天、檢索所有每個月18日的入庫記錄,進行這些處理就需要使用日期時間函式。SQL中提供了豐富的日期時間函式用於完成這些功能,本節將對這些日期時間函式進行詳

SQL 基礎及時間函式

sql知識點  一.7種常見型別     int 整數型別 -2^31到2^31-1     decimal 小數型別 -10^38+1到10^38-1     char 儲存固定長度非unicode字元,最多可存8000個位

PostgreSQL的日期/時間函式

零、前言 公司裡有一臺阿里雲RDS資料庫用了PPAS(Postgres PlusTM Advanced Server),在處理日期/時間時遇到一些問題,花了點時間整理如下。 一、獲取當前時間 select now() select current_timestamp se

**mysql日期時間函式**

-- MySQL日期時間處理函式 -- 當前日期:2017-05-12(突然發現今天512,是不是會拉防空警報) SELECT NOW() FROM DUAL;-- 當前日期時間:2017-05-12 11:41:47 -- 在MySQL裡也存在和Ora

MySql常用日期時間函式

返回當前的日期和時間 select SYSDATE(); --2018-11-13 17:57:37 select NOW(); --2018-11-13 17:57:37 select CURDATE(); --2018-11-13 select CURTIME();

sql server中quotename()函式的用法(轉載)

操作sql server尤其是寫儲存過程時,要用到各種各樣的函式,今天就總結一個quotename()的用法。1.語法: quotename('character_string'[,'quote_character']) []裡面的內容說明可以省略,預設情況下,說明用'[]'引用。