ReportService的日期参数计算的一个技巧

 

 

公司的食堂每个月需要统计当月的就餐情况,但是,他们不是按照自然月来计算,而是根据上个月的21号到本月的20号。因此要求我提供的两个参数,开始日期和结束日期的默认值就是这两个日期。


VBscript函数可以应用于reportingService的计算公式,因此,我先从参数的全局参数中的ExcutionTime中获取当前时间,然后,通过dateadd()函数来获取上个月的日期,最后,要将日期定位到上个月21日,我曾经使用日期函数进行计算,基本算法是获取当前取得的日期是当月的第几天,然后,计算出这一天和21日之间差几天,然后,用dateadd()函数将参数定位到21日。这样做比较麻烦,或来我想到了format()函数,我就利用这个函数计算出我所要的日期:

开始日期=cdate(format(dateadd(dateinterval.month,-1, Globals!ExecutionTime ),"yyyy-MM-21"))

结束日期==cdate( format(Globals!ExecutionTime,"yyyy-MM-20"))

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

想好点

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值