PostgreSQL 取前一列不为 NULL

PostgreSQL 取前一列不为 NULL 的值

案例:假设有如下一个表,其结构和数据如下。根据需求写出对应的 SQL。

date lv income

2021-01-01 1.1 100

2021-01-02 1.2 300

2021-01-03 1.3 301

2021-01-05 303

2021-01-06 1.8 304

2021-01-07 1.9 305

2021-01-04 302

需求:当 lv 为 NULL 时,取 date 小于当前 date 的 lv 不为 NULL 的 date 的 lv

解法1:

SELECT date,

lv,

income,

CASE WHEN lv IS NOT NULL THEN lv ELSE(SELECT a.lv FROM tmp AS a WHERE a.date < b.date AND a.lv IS NOT NULL ORDER BY a.date DESC LIMIT 1) END AS lv

FROM tmp AS b

ORDER BY b.date;

解法2:

SELECT date,

lv,

income,

first_value(lv) over (partition by lvs order by date)

FROM (

SELECT date,

lv,

income,

SUM(CASE WHEN lv IS NULL THEN 0 ELSE 1 END) OVER (ORDER BY date) AS lvs

FROM tmp

ORDER BY date ASC ) AS b;

解法一的思路非常的巧妙,并且 SQL 的执行效率也不会很差。

相关推荐
电商API_180079052471 分钟前
获取淘宝商品视频API教程:从授权到落地实战
大数据·数据库·人工智能·数据分析·音视频
柒.梧.5 分钟前
深度解析Spring Bean生命周期以及LomBok插件
java·后端·spring
工业甲酰苯胺11 分钟前
使用 C# 和 SQL Server 自动化邮件中的用户分配数据处理
数据库·c#·自动化
Antoine-zxt14 分钟前
MySQL数据脱敏技术全解析:从原理到可视化实践
数据库·mysql
初子无爱18 分钟前
Java接入支付宝沙箱支付教程
java·开发语言
DemonAvenger18 分钟前
深入Redis Stream:打造高效消息队列系统的实战指南
数据库·redis·性能优化
萧曵 丶18 分钟前
MySQL Undo/Redo Log详解
数据库·mysql
程序猿零零漆22 分钟前
Spring之旅 - 记录学习 Spring 框架的过程和经验(十)基于注解配置的AOP使用
java·学习·spring
虎啊兄弟27 分钟前
RocketMQ面试题
数据库·rocketmq
J_liaty28 分钟前
MySQL EXPLAIN 深度解析与 SQL 优化实战
数据库·sql·mysql