应先用GENERATE_SERIES或递归CTE生成完整时间轴再LEFT JOIN补空,再用FIRST_VALUE()按非空值分组向前填充;LAG/LEAD仅在现有行内跳转,无法跨缺失时间点。用 LAG() 和 LEAD() 填充缺失的时间点时间序列中出现 NULL 不代表没数据,常是采集断点或聚合后空档。直接用 COALESCE() 硬填前值会出错------它不感知顺序,只认当前行。必须结合窗口函数按时间排序后取邻近非空值。LAG(col, 1) OVER (ORDER BY ts) 取上一行的 col,但若上一行也是 NULL,结果仍是 NULL要"一直往前找",得嵌套 COALESCE(LAG(...), LAG(..., 2), LAG(..., 3)),但深度难预估更稳的做法:先用 ROW_NUMBER() OVER (PARTITION BY grp ORDER BY ts) 构造连续分组(见下节),再用 FIRST_VALUE() 向前广播用 FIRST_VALUE() + 分组实现"向前填充到最近非空值"核心思路不是逐行查,而是把每个非空值当作锚点,向后覆盖所有直到下一个非空值之间的空行。这需要构造一个能区分"填充段"的分组标识 grp。先用 COUNT(col) OVER (ORDER BY ts ROWS UNBOUNDED PRECEDING) 生成递增组号:每遇到一个非空 col,计数加一,空值沿用前一个计数再对这个 grp 分组,用 FIRST_VALUE(col) OVER (PARTITION BY grp ORDER BY ts ROWS UNBOUNDED PRECEDING) 拿每组第一个非空值注意 ROWS UNBOUNDED PRECEDING 是必须的,否则默认 RANGE BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW 在等值时间戳下可能出错处理时间戳不连续时的"向后填充"陷阱如果原始数据本身存在时间断层(比如缺了 2024-05-01 的整条记录),LAG()/LEAD() 无法补全------它们只在现有行内跳转,不会凭空插入新时间点。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
爱吃提升1 分钟前
Python 多线程 threading + 多进程 multiprocessing 完整实操教程ourenjiang2 分钟前
【测试框架Junit】强制终止JVM进程许彰午6 分钟前
24_Java NIO核心组件桌面运维家6 分钟前
校园机房vDisk IDV云桌面建设方案价格参考念越9 分钟前
SQL 基础语法复习ULIi096kr10 分钟前
MySQL磁盘爆满快速排查方案:一键查询库表空间、定位占用大户(RDS/自建通用)华山令狐虫12 分钟前
告别手写 SQL——DBAPI 企业版 v4.6.0 推出 AI 助手Cx330❀14 分钟前
【MySQL基础】库与表的全面操纵指南lie..16 分钟前
基于大模型的智能客服系统部署与使用(二):接入前端可视化界面天丁o21 分钟前
企业 AI Agent 工程化落地:从需求边界到系统集成的 6 个环节