SQL Server administration and T-SQL development, Web Programming with ASP.NET, HTML5 and Javascript, Windows Phone 8 app development, SAP Smartforms and ABAP Programming, Windows 7, Visual Studio and MS Office software Kodyaz SQL Server and T-SQL Development Tutorials
Development resources, articles, tutorials, samples, codes and tools for .Net, SQL Server, Windows, Windows Phone, SAP and ABAP, like SAP UI5, Screen Personas, etc.

download SQL Server 2016
download SQL Server 2014

SQL Server DateAdd Function T-SQL Example

SQL Server DateAdd function returns date which is added a time inverval identified by "basic datetime interval units times a given number of times" to a specific input date or datetime parameter.

T-SQL developers can understand the above complex sql dateadd function definition by looking at the below T-SQL DATEADD syntax.

DATEADD (datepart, number, date)

The SQL Server DATEADD function takes 3 arguments:
DATEPART is used the unit of time interval which will used during tsql DATEADD function,
NUMBER is used to set the time span with the help of DATEPART argument, which will be added to the base datetime value,
DATE is the base datetime parameter value, the time span will be added to this DATE argument or will be substracted from this DATE argument.

The output of the SQL Server DateAdd function is just as the input Date argument sql data type.
If the Date argument is in sql DateTime data type, the SQL Server DateAdd function output is also in DateTime.
If the Date argument is in tsql Date data type, the DateAdd function return value is also in sql Date data type.
All possible SQL Server date and time data types are datetime, smalldatetime, date, time, datetime2, and datetimeoffset

Let's set up a basic sql DATEADD scenario in a SQL Server database platform.
Assume that you have a table which stores service desk requests. And this table has InsertDate column. There is a business requirement which requires you to create a control after 3 days later the InsertDate column value.
So you decide to add a new table column storing the datetime value which is 3 days later than the InsertDate column.
In the INSTEAD OF INSERT trigger, or the Computed Column will have a t-sql expression using SQL Server DateAdd shown like below :

--DATEADD (DD, 3, InsertDate)

DECLARE @followingdate DATETIME

SET @currentdate = GETDATE()
SET @followingdate = DATEADD(DD, 3, @currentdate)

SELECT @currentdate, @followingdate

It is obvious that if the t-sql developer wants to substract a certain time span then the Number argument should be a Negative value in the SQL Server DateAdd function.

-- DATEADD(MM, -1, DateArgument)


SET @currentdate = GETDATE()
SET @pastdate = DATEADD(MM, -1, @currentdate)

SELECT @currentdate, @pastdate

In order to use SQL Server DATEADD function extensively, a t-sql developer can use the following DATEADD DATEPART arguments.

DATEPART Argument (unit of time)DATEADD DATEPART Abbreviation
QuarterQ, QQ
MonthM, MM
DayOfYearDY, Y
DayDD, D
WeekWK, WW
WeekdayDW, W
MinuteMI, N
SecondS, SS

I can easily say that the most common used DATEPART DATEADD arguments are Year (yy), Month (mm), Day (dd), Hour (hh), and Minute (mi).
As a t-sql developer, if you memorize these DatePart abbreviations, it will be very easy for you to use SQL Server DateAdd function in your sql queries or sql scripts.

Please note that the Number argument in SQL Server DateAdd datetime function is in integer.
So is a value bigger than 2147483647 or smaller than -2147483648 will cause an arithmetic overflow error.

SELECT DATEADD(dd, 2147483647, GETDATE())
SELECT DATEADD(dd, -2147483649, GETDATE())
-- Msg 8115, Level 16, State 2, Line 1
-- Arithmetic overflow error converting expression to data type int.

One important point with SQL Server DATEADD function while using with MONTH interval is the end dates of the months.
For example, if the base date is the 31st of the month, then if one month is added using t-sql DATEADD, the result will be 31st, 30th or 28th (maybe 29th) of the following month.
Let's make a sample.

--declare @date datetime = '20111231'
declare @date date = '20111231'
 DATEADD(mm, 1, @date),
 DATEADD(mm, 2, @date),
 DATEADD(mm, 4, @date),
 DATEADD(mm, 14, @date)


Here below, t-sql developers can find SQL Server DateAdd function examples with different date and time data types as argument to the DateAdd function.

declare @smalldatetime smalldatetime = getdate()
declare @datetime datetime = getdate()
declare @date date = getdate()
declare @time time = getdate()

 @smalldatetime, DATEADD(mi, 45, @smalldatetime),
 @datetime, DATEADD(mi, 45, @datetime),
 @date, DATEADD(mm, 10, @date),
 @time, DATEADD(hh, 11, @time)

If the date argument data type and the time interval argument is not compatible, the sql engine will throw an sql exception like :

 @date, DATEADD(mi, 10, @date),
--Msg 9810, Level 16, State 1, Line 6
--The datepart minute is not supported by date function dateadd for data type date.
 @time, DATEADD(dd, 11, @time)
--Msg 9810, Level 16, State 1, Line 6
--The datepart day is not supported by date function dateadd for data type time.

Related SQL Resources

SQL Server Articles

SQL Server 2012

SQL Server Tools

SQL Blog

MS SQL Server Forums

Copyright © 2004 - 2017 Eralper YILMAZ. All rights reserved.
Community Server by Telligent Systems