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

相关推荐
老前端的功夫6 分钟前
【Java从入门到入土】06:String的72变:从字符串拼接到底层优化
java·开发语言
Insist7539 分钟前
Kingbase 彻底卸载+重装全流程(保姆级)
网络·数据库
又是忙碌的一天13 分钟前
Java 面向对象三大特性:封装、继承、多态深度解析
java·前端·python
lihao lihao13 分钟前
MySql内外连接
数据库·mysql
qq56801807617 分钟前
MySQL下载安装及配置
数据库·mysql
彭于晏Yan20 分钟前
Springboot实现连接多个ElasticSearch数据库
数据库·spring boot·elasticsearch
隔壁小邓25 分钟前
在Java中实现优雅的CQRS架构
java·开发语言·架构
河边小咸鱼31 分钟前
pdd校招实习生内推【实时更新链接】2027届实习、2026届春招
java·c++·golang
light blue bird32 分钟前
MES/ERP大数据报表条件索引查询组件
数据库·.net·winform·t-sql·大数据报表
wmfglpz8832 分钟前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python