dateadd()函数的语法格式:
dateadd(y[,m,d],int,expression)
在使用dateadd的过程中你会发现,当dateadd()函数的第一个参数为‘m‘时,dateadd()函数只单纯的在月份上加减某个整数值,但是有可能你会遇到这样的的问题,例如:日期是'2009-06-30'(月末)时,只想将该日期推前三个月,即'2009-03-31',此时如果使用dateadd(m,-3,'2009-06-30')函数显然不能达到你的要求,因为每年的三月份是月大,也就是有31天,而在三月份是存在30日的,所以使用dateadd(m,-3,'2009-06-30')得到的结果是'2009-03-30'日,显然跟你想要的结果是有出入的。
要想解决此问题,我们可以采用自定义函数来实现该功能:
create function dtadd(@ymd varchar(2),@count int,@dttime datetime)
returns datetime
as
begin
if @ymd='y'
begin
set @dttime=dateadd(y,@count,@dttime)
end
if @ymd='m'
begin
set @dttime=dateadd(d,-1,dateadd(m,1,substring(convert(varchar(10),dateadd(m,@count,@dttime),23),0,8)+'-1'))
end
if @ymd='d'
begin
set @dttime=dateadd(d,@count,@dttime)
end
return (@dttime)
end
现在进行测试:
select dbo.dtadd('m',-3,'2009-06-30') --注意:调用自定义函数时,必须添加前缀'dbo.',不然调用函数是会提示"'dtadd' 不是可以识别的 函数名。"
返回结果:
2009-03-31