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 分钟前
数据库技术发展趋势- 04.大数据技术
数据库·人工智能·数据挖掘
SatVision炼金士10 分钟前
SDK管理本地java版本
java·开发语言·sdkman
独自破碎E15 分钟前
什么时候@Async会失效?
java·开发语言
山峰哥16 分钟前
SQL调优实战指南:从索引设计到高并发场景优化全链路解析
大数据·汇编·数据库·sql·编辑器·区块链
zbguolei17 分钟前
上传 Excel 文件进行数据库比对
数据库·excel
+VX:Fegn089522 分钟前
计算机毕业设计|基于springboot + vue在线教育学习系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·学习·课程设计
KG_LLM图谱增强大模型24 分钟前
企业级实用本体论及构建指南系列(1/4):Palantir 数据建模的哲学与实践
数据库·oracle·palantir
独自破碎E34 分钟前
Leetcode1499满足不等式的最大值
java·开发语言
记得开心一点嘛40 分钟前
使用ShardingSphere进行分库分表
数据库·mysql
最贪吃的虎40 分钟前
Java基础之泛型
java·运维·jvm·分布式·后端