欢迎光临
我们一直在努力

oracle 行转列

 Create   table   test   (name   char(10),km   char(10),cj   Number)  
   
  insert   into   test   values(‘
张三‘,’语文‘,80)  
  insert   into   test   values(‘
张三‘,’数学‘,86)  
  insert   into   test   values(‘
张三‘,’英语‘,75)  
  insert   into   test   values(‘
李四‘,’语文‘,78)  
  insert   into   test   values(‘
李四‘,’数学‘,85)  
  insert   into   test   values(‘
李四‘,’英语‘,78)  
   
  commit;  
 
怎样实现成这样:  
  name    
语文     数学     英语  
 
李四     78         85         83  
 
张三     80         86         75  

select    
  name,  
  sum(decode(km,’
语文‘,cj,0)   语文,  
  sum(decode(km,’
数学‘,cj,0)   数学,  
  sum(decode(km,’
英语‘,cj,0)   英语  
  from   test   group   by   nameTop

赞(0)
【声明】:本博客不参与任何交易,也非中介,仅记录个人感兴趣的主机测评结果和优惠活动,内容均不作直接、间接、法定、约定的保证。访问本博客请务必遵守有关互联网的相关法律、规定与规则。一旦您访问本博客,即表示您已经知晓并接受了此声明通告。