Sqlserver時間函式用法(二)

2022-03-28 10:56:13 字數 3835 閱讀 3280

--1. 當前系統日期、時間

select getdate() --2015-01-06 09:27:27.277

--2.時間操作 dateadd 在向指定日期加上一段時間的基礎上,返回新的 datetime 值

dateadd(datepart,number,date)

注:datepart : year(yy, yyyy) | quarter(qq,q) | month(mm,m) | week(ww,wk) | day(dd,dy) | hour(h) | minute(mi,n) |

second (ss,s)| millisecond(ms)

date 引數是合法的日期表示式。number 是您希望新增的間隔數;對於未來的時間,此數是正數,對於過去的時間,此數是負數。

例:select getdate()

select dateadd(year,1,getdate()) --2016-01-06 09:27:27.277

select dateadd(month,1,getdate()) --2017-02-06 09:27:27.277

select dateadd(day,1,getdate()) --2015-01-07 09:27:27.277

select dateadd(week,1,getdate()) --2015-01-13 09:27:27.277

select dateadd(weekday,1,getdate()) --2015-01-07 09:27:27.277

select dateadd(hour,1,getdate()) --2015-01-06 10:27:27.277

select dateadd(minute,1,getdate()) --2015-01-06 09:28:27.277

select dateadd(second,1,getdate()) --2015-01-06 09:28:28.277

--3. datediff 返回跨兩個指定日期的日期和時間邊界數。

datediff( date-part, startdate, enddate )

注:datepart : year(yy, yyyy) | quarter(qq,q) | month(mm,m) | week(ww,wk) | day(dd,dy) | hour(h) | minute(mi,n) |

second (ss,s)| millisecond(ms)

startdate 和 enddate 引數是合法的日期表示式。

返回值:(enddate)-(startdate)

例:select datediff(year,getdate(),dateadd(year,2,getdate())) --返回:2

select * from crm_contract where datediff(month,subtime,getdate())=0 --檢視crm_contract申請時間subtime是本月的資料

--4. datepart 函式用於返回日期/時間的單獨部分,比如年、月、日、小時、分鐘等等。

--如果需要得到自己需要的日期,則需要講日期時間格式化

select datepart(year, getdate()) as '年份'

select datepart(month, getdate()) as '月份'

select datepart(day, getdate()) as '日期'

select datepart(week, getdate()) as '本年第幾周數'

select (datepart(weekday, getdate())-1) as '今天是週幾?'

select datepart(hour, getdate()) as '小時'

select datepart(minute, getdate()) as '分鐘'

select datepart(second, getdate()) as '秒時'

--5. datename 返回代表指定日期的指定日期部分的字串

select datename(weekday, getdate()) as '今天是星期幾?'

select datename(month,convert(varchar(10), getdate(),126)) as '今天是幾月份?'

select datename(day,convert(varchar(10), getdate(),126)) as '今天是幾號?'

select datename(year,convert(varchar(10), getdate(),126)) as '今年是哪年?'

--上週周一

select dateadd(wk, datediff(wk,0,getdate()),-7)

--上週周天

select dateadd(wk, datediff(wk,0,getdate()),-1)

--.本週周一

select dateadd(wk, datediff(wk,0,getdate()),0)

--.本週周天

select dateadd(wk,datediff(wk,0,getdate()),6)

--下週周一

select dateadd(wk,datediff(wk,0,getdate()),7)

--下週周天

select dateadd(wk,datediff(wk,0,getdate()),13)

--1.本月第一天

select dateadd(mm, datediff(mm,0,getdate()), 0)

--.本月最後一天

select dateadd(ms,-3,dateadd(mm, datediff(m,0,getdate())+1, 0))

--.本週星期一

select dateadd(wk, datediff(wk,0,getdate()), 0)

--.本週星期天

select dateadd(wk,datediff(wk,0,getdate()),6)

--.本年第一天

select dateadd(yy, datediff(yy,0,getdate()), 0)

--.本年最後一天

select dateadd(ms,-3,dateadd(yy, datediff(yy,0,getdate())+1, 0))

--.本季度第一天

select dateadd(qq, datediff(qq,0,getdate()), 0)

--.當天的半夜

select dateadd(dd, datediff(dd,0,getdate()), 0)

--.上個月的最後一天

select dateadd(ms,-3,dateadd(mm, datediff(mm,0,getdate()), 0))

--.去年的最後一天

select dateadd(ms,-3,dateadd(yy, datediff(yy,0,getdate()), 0))

--.本月的第乙個星期一

select dateadd(wk,

datediff(wk,0,dateadd(dd,6-datepart(day,getdate()),getdate())), 0)

sqlserver 時間函式用法

1.dateadd datepart,number,date 現在,我們希望向 orderdate 新增 2 天,這樣就可以找到付款日期,我們使用如下 select 語句 select orderid,dateadd day,2,orderdate as orderpaydate from orde...

SqlServer 時間函式

1 getdate 取得當前日期時間 2 dateadd 標記,增量,時間 例 select dateadd year,2,getdate 當前時間增加兩年 select dateadd day,2,getdate 當前時間增加兩天 3 datepart 標記,時間 例 select datepar...

SQLSERVER時間函式

一 sql server日期時間函式 sql server中的日期與時間函式 1.當前系統日期 時間 select getdate 2.dateadd 在向指定日期加上一段時間的基礎上,返回新的 datetime 值 例如 向日期加上2天 select dateadd day,2,2004 10 1...