sql - 如何在 PostgreSQL 查询中跳过空值?
问题描述
我在 postgresql 的数据库表名“c_hw_day”中有一个查询
select pr.c_period_id,
unnest(array_agg_mult(array[hd.wd1,hd.wd2,hd.wd3,hd.wd4,hd.wd5,hd.wd6,hd.wd7,hd.wd8,hd.wd9,hd.wd10,hd.hd1,hd.hd2,hd.hd2,hd.hd3,hd.hd4,hd.hd5,hd.hd6,hd.hd7,hd.hd8,hd.hd9,hd.hd10])) as wd_hd
from c_hw_day hd
left join c_period pr on (hd.c_period_id = pr.c_period_id)
group by 1
结果像
| ID | Weekend |
----------+-----------------------
| 1000051 | 2018-11-30 00:00:00 |
| 1000051 | |
| 1000051 | |
| 1000051 | 2018-12-07 00:00:00 |
| 1000051 | |
| 1000051 | |
| 1000051 | |
| 1000051 | 2018-12-14 00:00:00 |
我想跳过空值
| ID | Weekend |
----------+-----------------------
| 1000051 | 2018-11-30 00:00:00 |
| 1000051 | 2018-12-07 00:00:00 |
| 1000051 | 2018-12-14 00:00:00 |
解决方案
我不会使用数组来做到这一点。我只会使用横向连接:
select pr.c_period_id, wd_hd
from c_hw_day hd left join
c_period pr
on hd.c_period_id = pr.c_period_id lateral join
(values (hd.wd1, hd.wd2, hd.wd3, hd.wd4, hd.wd5, hd.wd6, hd.wd7, hd.wd8, hd.wd9, hd.wd10, hd.hd1, hd.hd2, hd.hd2, hd.hd3, hd.hd4, hd.hd5, hd.hd6, hd.hd7, hd.hd8, hd.hd9, hd.hd10
) v(hd)
where hd is not null;
这个逻辑要清楚得多。如果没有外部group by
,我怀疑它也会更快。
推荐阅读
- html - 当前课堂主题
- javascript - 在场景中的 Mapbox-gl 中“单击”时不会触发“mouseDown”事件
- typescript - 定义对象键但推断值
- javascript - 在 Google 表格中的表格顶部添加 fow
- html - 将宽度设置为 100% 以上后,div 水平向右移动
- javascript - 仅向弹出图像添加文本
- .htaccess - 尝试使用 .htaccess 进行 www 和 https 重定向
- javascript - 合并两个具有相同键的对象并将值转换为数组
- google-cloud-platform - Google Cloud Shell 一直停留在“配置您的 Cloud Shell 机器”上好几个小时了
- javascript - 导入的 three.js 模块 OrbitControls “未定义”