如何解决PostgreSQL中多行合并成多列
这是表格中的数据
item_code | name_type | name_value |
---|---|---|
1 | 完整 | 项目 1 全名 |
1 | 短 | 项目 1 简称 |
1 | 一半 | item 1 半名 |
1 | 半 | 项目 1 半名称 |
2 | 短 | 项目 2 简称 |
3 | 一半 | 项目 3 半名称 |
我想要的输出如下
item_code | 全名 | short_name | half_name |
---|---|---|---|
1 | 项目 1 全名 | 项目 1 简称 | item 1 半名 |
2 | - | 项目 2 简称 | - |
3 | - | - | 项目 3 半名称 |
我使用了 case 语句,但没有用。
select item_code,case name_type
when 'full' then name_value
end as full_name
case name_type
when 'short' then name_value
end as short_name
case name_type
when 'half' then name_value
end as half_name;
解决方法
您需要按 item_code 分组以获得每组的一行,然后使用像 max() 这样的聚合来获得每组的非空值:
select
item_code,max(
case name_type
when 'full' then name_value
end
) as full_name,max(
case name_type
when 'short' then name_value
end
) as short_name,max(
case name_type
when 'half' then name_value
end
) as half_name
from t
group by 1;
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。