PostgreSQL如何行转列
方法一:group by + sum + case when
select name,
sum(case when zbfm='年龄' then value else 0 end) as 年龄,
sum(case when zbfm='身高' then value else 0 end) as 身高,
sum(case when zbfm='体重' then value else 0 end) as 体重
from test group by name
having name like '%1' and length(name)=4 order by 年龄 desc
方法二:用postgresql的crosstab交叉函数
crosstab(unknown, unknown) does not exist
select * from
crosstab(
'select name,zbfm,value from test where name like ''%1'' and length(name)=4',$$values('年龄'), ('身高'), ('体重')$$)
as score(name text, 年龄 int, 身高 int, 体重 int)
order by 年龄 desc
方法三:group by + string_agg + split_part(分组,行转列,字符切割)文章来源:https://www.toymoban.com/news/detail-515050.html
select name,
split_part(split_part(temp,',',1),':',2) as 年龄,
split_part(split_part(temp,',',2),':',2) as 身高,
split_part(split_part(temp,',',3),':',2) as 体重
from(
select name, string_agg(zbfm||':'||value,',') as temp from test
group by name
having name like '%1' and length(name)=4
) as t order by 年龄 desc
group by + string_agg文章来源地址https://www.toymoban.com/news/detail-515050.html
select name, string_agg(zbfm||':'||value,',') from test
group by name
having name like '%1' and length(name)=4
到了这里,关于PostgreSQL如何行转列的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!