首页 > 代码库 > sql实现行列转换
sql实现行列转换
姓名 | 科目 | 成绩 |
牛芬 | 语文 | 81 |
牛芬 | 数学 | 88 |
牛芬 | 英语 | 84 |
张三 | 语文 | 90 |
张三 | 数学 | 98 |
张三 | 英语 | 90 |
(表一)
现有一个表如(表一)
姓名 | 语文 | 数学 | 英语 |
牛芬 | 81 | 88 | 84 |
张三 | 90 | 98 | 90 |
想要转换为(表二)
sql:select stuName as 姓名,chinese as 语文,math as 数学,english as 英文 from(
select sutName,
case subject when chinese then score end as chinese,
case subject when math then score end as math,
case subject when english then score end as english
from table) as tmp
group by stuName
若要把(表二)转换成(表一)
postgresql里面有个unnest函数可以使用:
select stuName,unnest(array[‘chinese‘,‘math‘,‘english‘]) as subject,unnest(array[chinest,math,englist]) as score from table group by stuName
就这么简单
sql实现行列转换
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。