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;