SQL SERVER 获取多少天、多少星期、多少月后的日期

IF EXISTS( SELECT 1 FROM sysobjects WHERE name = 'yh_fn_get_schedule_date')
	DROP FUNCTION	yh_fn_get_schedule_date
GO
CREATE FUNCTION	yh_fn_get_schedule_date(@frequency CHAR(1),@interval_num INT ,@intervar_day INT,@period int)
	RETURNS DATETIME
AS
BEGIN
	--根据参数获取执行日期
	--传入参数:@frequency:频率'D','W','M'
	--传入参数:@interval_num 频率间隔:间隔M天,M周,M月
	--传入参数:@intervar_day 执行价格:每M月N号;每M周星期N
	--传入参数:@period	期数 --第I期
	--返回结果:执行日期
	DECLARE @weekday INT ,@monthday INT ,@monthlastday INT,@currmonthlastdate DATETIME,@lastmonthlastdate DATETIME,@month_qty INT
	IF ISNULL(@period,0) = 0 
	BEGIN
		SET @period = 1
	end 
	DECLARE	@rtn_date	DATETIME
	IF @frequency = 'D' --按天数
	BEGIN
		SELECT @rtn_date = DATEADD(D,@interval_num * @period,GETDATE())		
	END
	ELSE IF @frequency = 'W'--按星期
	BEGIN	
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值