您的位置:首页 > 数据库

SQL行转列

2015-11-20 16:55 288 查看
建表:

create table studentinfo(

name varchar(20) ,
subject varchar(20),
score number(3,1));

插入记录:

insert into studentinfo values('张三','语文',69);

insert into studentinfo values('张三','数学',70);

insert into studentinfo values('李四','语文',20);

里面的记录为:



我们想要的结果为:



通过下面的sql可以实现:

select a 姓名,max(a1) 语文,max(a2) 数学
from (
    select a, case when b = '语文' then c else null end as a1,
         case when b = '数学' then c else null end as a2
    from
    (select name a,subject b,score c from studentinfo) x
) y
group by a;

作者:caobotao
出处: /article/5260173.html
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接,否则保留追究法律责任的权利。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: