用递归CTE生成连续日期是通用推荐方法,适用于PostgreSQL、SQL Server、Oracle、MySQL 8.0+等;以生成近30天为例,从起始日期逐日递增构造date_series。

SQL中生成连续日期或时间维度,常用于报表、BI分析、时间序列补全等场景。核心思路是:用递归、数字序列或系统表构造连续时间点,再与业务数据左连接实现“补齐”。不同数据库语法略有差异,但逻辑一致。
适用于 PostgreSQL、SQL Server、Oracle、MySQL 8.0+ 等支持递归 CTE 的数据库。以生成近30天日期为例:
WITH RECURSIVE date_series AS ( SELECT '2025-01-01'::DATE AS dt UNION ALL SELECT dt + INTERVAL '1 day' FROM date_series WHERE dt < '2025-01-30' ) SELECT dt FROM date_series;
说明:
• 起始日期和结束日期可替换为变量或子查询结果
• PostgreSQL 用 '1 day',SQL Server 用 DATEADD(day, 1, dt),MySQL 用 DATE_ADD(dt, INTERVAL 1 DAY)
• 注意设置最大递归深度(如 MySQL 需 SET cte_max_recursion_depth = 1000)
对不支持递归 CTE 的数据库(如 MySQL 5.7、SQLite),可用“数字表”模拟。先构造一串连续整数,再转为日期:
-- 以MySQL 5.7为例:用JOIN生成0~99的数字
SELECT DATE_ADD('2025-01-01', INTERVAL n DAY) AS dt
FROM (
SELECT t1.i + t2.i * 10 AS n
FROM (SELECT 0 i UNION SELECT 1 UNION SELECT 2 UNION SELECT 3 UNION SELECT 4
UNION SELECT 5 UNION SELECT 6 UNION SELECT 7 UNION SELECT 8 UNION SELECT 9) t1,
(SELECT 0 i UNION SELECT 1 UNION SELECT 2 UNION SELECT 3 UNION SELECT 4
UNION SELECT 5 UNION SELECT 6 UNION SELECT 7 UNION SELECT 8 UNION SELECT 9) t2
) nums
WHERE n BETWEEN 0 AND 29;说明:
• 两个 0–9 表 JOIN 可得 0–99,足够覆盖常见月度范围
• 替换起止值即可调整日期区间
• 可封装为视图或临时表复用
生成日期维度后,关键一步是关联实际业务数据,把缺失日期的指标补为 0 或 NULL:
MacsMind
电商AI超级智能客服
192
查看详情
WITH date_series AS (
SELECT DATE_ADD('2025-01-01', INTERVAL n DAY) AS dt
FROM (...) nums -- 上面的数字生成逻辑
),
order_summary AS (
SELECT DATE(order_time) AS order_date, COUNT(*) AS cnt
FROM orders
WHERE order_time >= '2025-01-01' AND order_time < '2025-02-01'
GROUP BY DATE(order_time)
)
SELECT ds.dt, COALESCE(os.cnt, 0) AS order_count
FROM date_series ds
LEFT JOIN order_summary os ON ds.dt = os.order_date
ORDER BY ds.dt;说明:
• LEFT JOIN 确保所有日期都保留
• COALESCE 或 ISNULL 把空值转为 0,便于图表展示
• 若需小时级补齐,把 INTERVAL 改为 '1 ho
ur',并用 DATE_FORMAT(dt, '%Y-%m-%d %H:00') 对齐粒度
如果频繁需要日期维,建议建一张物理表(date_dim),包含年、月、日、星期、是否节假日等字段:
不复杂但容易忽略:日期生成时注意时区对齐,尤其是跨时区业务;若用字符串拼接日期,务必用标准格式(如 'YYYY-MM-DD'),避免隐式转换出错。
以上就是SQL如何生成连续日期_时间维度补齐方法讲解【教程】的详细内容,更多请关注其它相关文章!
# 数据查询
# 云阳的可靠网站建设
# 中山建设企业网站建设
# 武汉网站如何优化推广
# 优化seo管用易速达
# 机构联盟营销推广区别
# seo内外链
# seo培训推广工具
# 网站建设销售案例范文
# 临汾网站推广sem
# 站内seo应该怎样做
# 尤其是
# mysql
# 检测方法
# 复用
# 隐式
# 适用于
# 为例
# 分区表
# 补齐
# 递归
# yy
# 隐式转换
# oracle
相关栏目:
【
Google疑问12 】
【
Facebook疑问10 】
【
优化推广96088 】
【
技术知识133117 】
【
IDC资讯59369 】
【
网络运营7196 】
【
IT资讯61894 】
相关推荐:
手机坏了微信聊天记录怎么导出来 新手机恢复聊天记录技巧
招商淘客入门指南
win11关机几秒又自己开机 Win11关机自动重启问题修复
OTT月报 | 2025年9月智能电视大数据报告
QQ网页版官方账号登录入口 QQ网页版网页版入口快速导航
苹果SE如何开启单手模式_苹果SE单手操作功能
快手缓存清理方法
Win10运行窗口在哪里打开 Win10调出运行命令框快捷键【技巧】
Symfony路由参数转换器:实体存在性验证与错误处理策略
百度识图图像分析 百度识图识别平台
汽车之家网页版免费登录_汽车之家官网首页直接进入
2025SNH48年度青春盛典门票价格及购买方式
J*a中导出MySQL表为SQL脚本的两种方法
汽水音乐在线入口 汽水音乐网页端官方页面快速打开
百度地图离线地图无法加载如何解决 百度地图离线地图加载优化方法
《顺丰同城骑士》查看我的技能方法
《合金装备4》有望推出重制版!制作人发话了
魔法祈幻界兑换码礼包大全
海棠书屋官方在线书籍入口 海棠书屋文学作品浏览官网链接
使用AI在VS Code中将代码从一种语言翻译成另一种
韩小圈网页版PC端入口 韩小圈网页版官方网站入口
Lar*el 中高效执行多列更新:单次查询实现
Go语言反射机制下访问嵌入结构体中的被遮蔽方法
创客贴登录页面入口 创客贴网页版最新网址链接
Animex动漫社社登录官网 Animex动漫社资源社入口直达
Python中处理嵌套字典与列表的数据提取与过滤教程
批改网官网首页登录 批改网学生用户登录入口
win11如何诊断DirectX问题 Win11运行dxdiag工具排查显卡故障【排错】
虫虫漫画绿色安全入口_虫虫漫画绿色安全入口安全看漫画
sublime如何撤销关闭的标签页_sublime重新打开已关闭文件技巧
Word 2003字体大小设置方法
抖音号升级企业号怎么改名字?升级企业号有哪些好处?
三星M34录音变声问题_Samsung M34麦克风调整
店铺如何做视频号推广?做视频号推广有用吗?
iCloud官方网站 iCloud网页版在线登录入口
Pydantic 中“schema”字段命名冲突的解决方案
J*aScript模拟悬停与点击:自动化网页动态元素交互指南
Bootstrap 5导航栏折叠功能失效:数据属性迁移指南
手机雨课堂网页版入口免登录 雨课堂网页版可点击直接进入
Dagster资产间数据传递与用户配置管理教程
VBA Outlook邮件自动化:高效集成Excel数据与列标题的策略
《盗墓笔记手游》技能介绍
C++怎么解决数值计算中的精度问题_C++浮点数误差与数值稳定性分析
win11怎么启用或禁用休眠 Win11 powercfg命令管理休眠文件【技巧】
MySQL多重关联查询:利用别名高效获取同一表的多个关联字段
口腔诊所管理软件推荐
CSS如何使用outline-offset与颜色组合突出元素边框
德邦快递收费标准详解
vivo云服务一直提示空间不足怎么办 怎么办vivo云服务老是提示空间不足
阿里旺旺电脑网页版入口 阿里旺旺电脑版网页登录入口
2025-12-20
运城市盐湖区信雨科技有限公司是一家深耕海外推广领域十年的专业服务商,作为谷歌推广与Facebook广告全球合作伙伴,聚焦外贸企业出海痛点,以数字化营销为核心,提供一站式海外营销解决方案。公司凭借十年行业沉淀与平台官方资源加持,打破传统外贸获客壁垒,助力企业高效开拓全球市场,成为中小企业出海的可靠合作伙伴。