首页 > 代码库 > sql实现行列转换

sql实现行列转换


姓名科目成绩
牛芬语文81
牛芬数学88
牛芬英语84
张三语文90
张三数学98
张三英语90

(表一)

现有一个表如(表一)

姓名语文数学英语
牛芬818884
张三909890
(表二)

想要转换为(表二)

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实现行列转换