zoukankan      html  css  js  c++  java
  • sql server行列转化

    •  行列转换:  
    [sql] view plain copy
     
    1. 姓名 课程 分数  
    2. 张三 语文 74  
    3. 张三 数学 83  
    4. 张三 物理 93  
    5. 李四 语文 74  
    6. 李四 数学 84  
    7. 李四 物理 94  
    8.   
    9. 想变成(得到如下结果):   
    10. 姓名 语文 数学 物理   
    11. ---- ---- ---- ----  
    12. 李四 74   84   94  
    13. 张三 74   83   93  
    14.   
    15. create table sc(姓名 varchar(10),课程 varchar(10),分数 float)  
    16.   
    17. insert into sc  
    18. select '张三','语文',74  
    19. union  
    20. select '张三','数学',83  
    21. union  
    22. select '张三','物理',93  
    23. union  
    24. select '李四','语文',74  
    25. union  
    26. select '李四','数学',84  
    27. union  
    28. select '李四','物理',94  
    29.   
    30. 方法1:  
    31. declare @sql varchar(max)  
    32. set @sql='select '  
    33. select @sql=@sql+', max(case when 课程='''+课程+''' then 分数 else '''' end)['+课程+']' from (select distinct 课程 from sc)t  
    34.   
    35. set @sql = STUFF(@sql,8,1,'')  
    36. print @sql  
    37. set @sql=@sql+' ,姓名 from sc group by 姓名'  
    38. exec(@sql)  
    39.   
    40. 方法2:  
    41.   
    42. select 姓名,数学,物理,语文 from sc pivot( max(分数) for 课程 in(数学,物理,语文))t  
    43.   
    44.   
    45. 方法3:  
    46. declare @sql varchar(8000)  
    47. select @sql = isnull(@sql + '],[' , '') + 课程 from sc group by 课程  
    48. print @sql  
    49. set @sql = '[' + @sql + ']'  
    50. exec ('select * from (select * from tb) a pivot (max(分数) for 课程 in (' + @sql + ')) b')  
  • 相关阅读:
    JavaScript之DOM
    MapReduce多种join实现实例分析(一)
    JavaScript的文档对象模型DOM
    JavaScript原生实现观察者模式
    Idea环境下git 图形化操作
    一分钟教你如何实现唯美的文字描边
    Redis集群
    JAVA线程池的实际运用
    Java 线程池(ThreadPoolExecutor)原理解析
    win7开始菜单路径
  • 原文地址:https://www.cnblogs.com/johnblogs/p/8391803.html
Copyright © 2011-2022 走看看