DateADD日期Sql

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

转载于:https://www.cnblogs.com/Li-yuan/p/6180391.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值