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 的执行效率也不会很差。

相关推荐
醇氧17 小时前
【Linux】 安装 Azul Zulu JDK
java·linux·运维
多多*18 小时前
2026年1月3日八股记录
java·开发语言·windows·tcp/ip·mybatis
张较瘦_18 小时前
Springboot3 | 核心注解实战教程
java·spring boot
太理摆烂哥18 小时前
C++之异常
java·开发语言·jvm
pe7er18 小时前
如何阅读英文文档
java·前端·后端
期待のcode18 小时前
java异常
java·开发语言
勇往直前plus18 小时前
Python 类与实例对象的内存存储
java·开发语言·python
java_t_t19 小时前
Java属性解析映射到Json
java·json
先做个垃圾出来………19 小时前
Python位运算及操作
java·前端·python
一只大黄猫19 小时前
【数据库-入门2】基本概念
数据库