SQL中DATEADD和DATEDIFF的使用方法

DATEADD函数计算一个日期通过给时间间隔加减来获得一个新的日期,DATEDIFF函数计算两个日期之间的小时、天、周、月、年等时间间隔总数。

1、SQL Server DATEADD() 函数

定义和用法

DATEADD() 函数在日期中添加或减去指定的时间间隔。

语法

DATEADD(datepart,number,date)

date 参数是合法的日期表达式。number 是您希望添加的间隔数;对于未来的时间,此数是正数,对于过去的时间,此数是负数。

datepart 参数可以是下列的值:

datepart缩写
yy, yyyy
季度qq, q
mm, m
年中的日dy, y
dd, d
wk, ww
星期dw, w
小时hh
分钟mi, n
ss, s
毫秒ms
微妙mcs
纳秒ns

实例

假设我们有下面这个 "Orders" 表:

OrderIdProductNameOrderDate
1'Computer'2008-12-29 16:25:46.635

现在,我们希望向 "OrderDate" 添加 2 天,这样就可以找到付款日期。

我们使用如下 SELECT 语句:

SELECT OrderId,DATEADD(day,2,OrderDate) AS OrderPayDate
FROM Orders

结果:

OrderIdOrderPayDate
12008-12-31 16:25:46.635
date也可以使用函数,比如今天是2016-02-21.


2、SQL Server DATEDIFF() 函数

定义和用法

DATEDIFF() 函数返回两个日期之间的天数。

语法

DATEDIFF(datepart,startdate,enddate)

startdate 和 enddate 参数是合法的日期表达式。

datepart 参数可以是下列的值:

datepart缩写
yy, yyyy
季度qq, q
mm, m
年中的日dy, y
dd, d
wk, ww
星期dw, w
小时hh
分钟mi, n
ss, s
毫秒ms
微妙mcs
纳秒ns

实例

例子 1

使用如下 SELECT 语句:

SELECT DATEDIFF(day,'2008-12-29','2008-12-30') AS DiffDate

结果:

DiffDate
1

例子 2

使用如下 SELECT 语句:

SELECT DATEDIFF(day,'2008-12-30','2008-12-29') AS DiffDate

结果:

DiffDate
-1


DATEADD和DATEDIFF可以组合获取指定时间。

本月的第一天:

[html]  view plain  copy
  1. Select dateadd(ms,0,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)) as 时间  

本月的最后一天:

[html]  view plain  copy
  1. Select dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0))  

上个月的最后一天:

[sql]  view plain  copy
  1. Select dateadd(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)) as 时间  

去年的最后一天:

[html]  view plain  copy
  1. Select dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))   
本年的最后一天:
[html]  view plain  copy
  1. Select dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0))  

2016-01-21的12个月前的那个月的第一天:
[html]  view plain  copy
  1. Select dateadd(mm,-12,DATEADD(mm, DATEDIFF(mm,0,'2016-01-21'), 0)) as 时间  


一年中指定周的第一天:

[sql]  view plain  copy
  1. DECLARE @本年第一天 datetime,@本年第一天是星期几 int,@Week int  
  2. set @本年第一天=DATEADD(ms,0,DATEADD(yy, DATEDIFF(yy,0,GETDATE()), 0))  
  3. set @本年第一天是星期几=DATEPART(dw,DATEADD(ms,0,DATEADD(yy, DATEDIFF(yy,0,GETDATE()), 0)))  
  4. set @Week=1--今年第一周  
  5. select DATEADD(day,(@Week-1)*7-@本年第一天是星期几+2,@本年第一天)  



转载:https://blog.csdn.net/Gordennizaicunzai/article/details/50710130

  • 9
    点赞
  • 58
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
SQL ServerDATEDIFF函数用于计算两个日期之间的差异。它的语法如下: DATEDIFF(interval, startdate, enddate) 其,interval参数指定要计算的时间间隔,可以是年("year"或"yy"),季度("quarter"或"qq"),月("month"或"mm"),周("week"或"wk"),日("day"或"dd"),小时("hour"或"hh"),分钟("minute"或"mi"),秒("second"或"ss")等等。\[2\] startdate和enddate参数分别是要计算的起始日期和结束日期。\[2\] 例如,如果要计算两个日期之间相差的年数,可以使用以下语句: SELECT DATEDIFF(year, startdate, enddate) 如果要计算两个日期之间相差的月数,可以使用以下语句: SELECT DATEDIFF(month, startdate, enddate) 如果要计算两个日期之间相差的天数,可以使用以下语句: SELECT DATEDIFF(day, startdate, enddate) 在SQL Server,还可以使用DATEADD函数来进行日期的加减运算。例如,要计算当前时间的一天前、当前时间和一天后的日期,可以使用以下语句: SELECT '一天前' AS type, DATEADD(day, -1, GETDATE()) AS time UNION ALL SELECT '当前时间' AS type, GETDATE() AS time UNION ALL SELECT '一天后' AS type, DATEADD(day, 1, GETDATE()) AS time\[3\] #### 引用[.reference_title] - *1* *3* [SQlServer的日期相减(间隔)dateadddatediff 函数](https://blog.csdn.net/qq_41674785/article/details/129953754)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [SQL ServerDatediff函数](https://blog.csdn.net/wjiaoling136/article/details/84716663)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值