sql server 生成本月日期的临时表

ps 在某项报表的数据echarts展示时,因为有的天没有数据,直接统计出来数据格式不合适,

需要没有数据的那天数据为0。

所以需要生成本月的临时表,值默认为0,然后更新对应天的值,然后直接输出前端的格式

-- 创建临时表
CREATE TABLE #TempDates (
    DateOfMonth DATE
);
 
-- 计算本月的第一天 
DECLARE @FirstDayOfMonth DATE;

--获取当前日期是第几个月 然后0加这个月数 获得日期
SET @FirstDayOfMonth = DATEADD(MONTH, DATEDIFF(MONTH, 0, GETDATE()), 0);
 
-- 插入本月的每一天
DECLARE @Counter INT;
SET @Counter = 0;
 --循环天数  取本月第一天加一个月减一天 获得这个月最后一天 然后获取天数
WHILE @Counter < DAY(DATEADD(DAY, -1, DATEADD(MONTH, 1, @FirstDayOfMonth)))
BEGIN

    --本月第一天加循环天数插入
    INSERT INTO #TempDates (DateOfMonth) VALUES (DATEADD(DAY, @Counter, @FirstDayOfMonth));
    SET @Counter = @Counter + 1;
END
 
-- 使用临时表
SELECT * FROM #TempDates;
 
-- 删除临时表
DROP TABLE #TempDates;

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值