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')  
  • 相关阅读:
    JS权威指南读书笔记(二)
    JS权威指南读书笔记(一)
    NodeList和HTMLCollection区别
    2016年前端技术展望
    Label标签for属性
    JavaScript Array vs new Array区别
    禁止滚动事件方法
    shim和polyfill 区别解释
    Html5知识精粹纪录
    前端url 相关设置获取总结
  • 原文地址:https://www.cnblogs.com/johnblogs/p/8391803.html
Copyright © 2011-2022 走看看