時間函數sql
下面的表格列出了 SQL Server 中最重要的內建日期函數:express
函數 | 描述 |
---|---|
GETDATE() | 返回當前日期和時間 |
DATEPART(Type,date) | 返回日期/時間的單獨部分 |
DATEADD(Type,number,date) | 在日期中添加或減去指定的時間間隔 |
DATEDIFF(Type,date1,date2) | 返回兩個日期之間的時間 |
CONVERT( data_type [ ( length ) ] , expression [ , style ]) | 用不一樣的格式顯示日期/時間 |
Type參很多天期類型枚舉函數
值 | 縮 寫(Sql Server) | Access 和 ASP | 說明 |
Year | Yy | yyyy | 年 1753 ~ 9999 |
Quarter | q | 季 1 ~ 4 | |
Month | Mm | m | 月1 ~ 12 |
Day of year | Dy | y | 一年的日數,一年中的第幾日 1-366 |
Day | Dd | d | 日,1-31 |
Weekday | Dw | w | 一週的日數,一週中的第幾日 1-7 |
Week | Wk | ww | 周,一年中的第幾周 0 ~ 51 |
Hour | Hh | h | 時0 ~ 23 |
Minute | Mi | n | 分鐘0 ~ 59 |
Second | Ss | s | 秒 0 ~ 59 |
Millisecond | Ms | - | 毫秒 0 ~ 999 |
例子:spa
--getdate 獲取當前時間 select getdate() --dateadd 原有時間加: 2013-02-17 13:20:16 此時間加12個月 select dateadd(MONTH,12,'2013-02-17 13:20:16') --返回:2014-02-17 13:20:16.000 (參數month能夠改成 day,year等日期加相應的值) --datediff 兩個時間的差 (後面-前面=返回值) select datediff(day,'2013-02-01','2013-02-18') --返回:17 (參數day能夠改成 month,year等日期加相應的值) --datepart 獲取日期的某個部分整數 select DATEPART(month, '2013-2-17') --返回 2 (參數month能夠改成 day,year等日期加相應的值) --datename 獲取指定部位的字符串 select datename(weekday, '2013-2-17') --返回 星期日 (參數weekday能夠改成 day,year等日期加相應的值) --day(), month(),year() 獲取指定部位的字符串 select day('2013-2-15') --返回15
Convert日期轉換函數code
時間格式轉換使用 CONVERT:CONVERT ( data_type [ ( length ) ] , expression [ , style ] )blog
data_type
目標系統所提供的數據類型,包括 bigint 和 sql_variant。不能使用用戶定義的數據類型。
參數
length
nchar、nvarchar、char、varchar、binary 或 varbinary 數據類型的可選參數。 ci
expression
是任何有效的 Microsoft® SQL Server™ 表達式。
style:風格
字符串
下面是日期格式的expressionget
Select CONVERT(varchar(100), GETDATE(), 0)-- 05 16 2006 10:57AM Select CONVERT(varchar(100), GETDATE(), 1)-- 05/16/06 Select CONVERT(varchar(100), GETDATE(), 2)-- 06.05.16 Select CONVERT(varchar(100), GETDATE(), 3)-- 16/05/06 Select CONVERT(varchar(100), GETDATE(), 4)-- 16.05.06 Select CONVERT(varchar(100), GETDATE(), 5)-- 16-05-06 Select CONVERT(varchar(100), GETDATE(), 6)-- 16 05 06 Select CONVERT(varchar(100), GETDATE(), 7)-- 05 16, 06 Select CONVERT(varchar(100), GETDATE(), 8)-- 10:57:46 Select CONVERT(varchar(100), GETDATE(), 9)-- 05 16 2006 10:57:46:827AM Select CONVERT(varchar(100), GETDATE(), 10)-- 05-16-06 Select CONVERT(varchar(100), GETDATE(), 11)-- 06/05/16 Select CONVERT(varchar(100), GETDATE(), 12)-- 060516 Select CONVERT(varchar(100), GETDATE(), 13)-- 16 05 2006 10:57:46:937 Select CONVERT(varchar(100), GETDATE(), 14)-- 10:57:46:967 Select CONVERT(varchar(100), GETDATE(), 20)-- 2006-05-16 10:57:47 Select CONVERT(varchar(100), GETDATE(), 21)-- 2006-05-16 10:57:47.157 Select CONVERT(varchar(100), GETDATE(), 22)-- 05/16/06 10:57:47 AM Select CONVERT(varchar(100), GETDATE(), 23)-- 2006-05-16 Select CONVERT(varchar(100), GETDATE(), 24)-- 10:57:47 Select CONVERT(varchar(100), GETDATE(), 25)-- 2006-05-16 10:57:47.250 Select CONVERT(varchar(100), GETDATE(), 100)-- 05 16 2006 10:57AM Select CONVERT(varchar(100), GETDATE(), 101)-- 05/16/2006 Select CONVERT(varchar(100), GETDATE(), 102)-- 2006.05.16 Select CONVERT(varchar(100), GETDATE(), 103)-- 16/05/2006 Select CONVERT(varchar(100), GETDATE(), 104)-- 16.05.2006 Select CONVERT(varchar(100), GETDATE(), 105)-- 16-05-2006 Select CONVERT(varchar(100), GETDATE(), 106)-- 16 05 2006 Select CONVERT(varchar(100), GETDATE(), 107)-- 05 16, 2006 Select CONVERT(varchar(100), GETDATE(), 108)-- 10:57:49 Select CONVERT(varchar(100), GETDATE(), 109)-- 05 16 2006 10:57:49:437AM Select CONVERT(varchar(100), GETDATE(), 110)-- 05-16-2006 Select CONVERT(varchar(100), GETDATE(), 111)-- 2006/05/16 Select CONVERT(varchar(100), GETDATE(), 112)-- 20060516 Select CONVERT(varchar(100), GETDATE(), 113)-- 16 05 2006 10:57:49:513 Select CONVERT(varchar(100), GETDATE(), 114)-- 10:57:49:547 Select CONVERT(varchar(100), GETDATE(), 120)-- 2006-05-16 10:57:49 Select CONVERT(varchar(100), GETDATE(), 121)-- 2006-05-16 10:57:49.700 Select CONVERT(varchar(100), GETDATE(), 126)-- 2006-05-16T10:57:49.827 Select CONVERT(varchar(100), GETDATE(), 130)-- 18 ???? ?????? 1427 10:57:49:907AM Select CONVERT(varchar(100), GETDATE(), 131)-- 18/04/1427 10:57:49:920AM