首页 > 代码库 > T-SQL 时间操作(dateadd ,datediff ,datepart ,datename )

T-SQL 时间操作(dateadd ,datediff ,datepart ,datename )

--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)

T-SQL 时间操作(dateadd ,datediff ,datepart ,datename )