Oracle行列互换 横表和纵表

行列互换  
Java代码    收藏代码
  1. /* 
  2. 在实际使用sql工作中总会碰到将某一列的值放到标题中显示.就是总说的行列转换或者互换. 
  3. 比如有如下数据: 
  4. ID NAME       KECHENG              CHENGJI 
  5. -- ---------- -------------------- ------- 
  6. 1  a          语文                 80      
  7. 2  a          数学                 70      
  8. 3  b          语文                 40      
  9. 4  b          数学                 100     
  10. 5  c          语文                 90      
  11. 6  c          数学                 92 
  12. 那末我要求显示的结果是: 
  13. NAME       YUWEN                  SHUXUE                 
  14. ---------- ---------------------- ---------------------- 
  15. a          80                     70    
  16. 也就是说把课程这一列放到行上显示.把成绩按照课程分配到相对应的行. 
  17. 我只介绍2中简单易用的方法,使用游标或者建立临时表的方法就不介绍了.效率很慢,不易理解. 
  18. 首先建立表: 
  19. */  
  20.   
  21. create table fzq  
  22. (  
  23. id varchar(2),  
  24. name varchar(10),  
  25. kecheng varchar(20),  
  26. chengji varchar(3)  
  27. );  
  28.   
  29.   
  30. --插入数据:  
  31. insert into fzq values ('1','a','语文','80');  
  32. insert into fzq values('2','a','shuxue','70');  
  33. insert into fzq values ('3','b','yuwen','40');  
  34. insert into fzq values ('4','b','shuxu','100');  
  35. insert into fzq values ('5','c','yuwen','90');  
  36. insert into fzq values ('6','c','shuxu','92');  
  37.   
  38. /*首先使用union.如果课程这列有多个值,那么脚本的代码就很长了.*/  
  39.   
  40. select name,sum(yuwen) yuwen,sum(shuxue) shuxue from  
  41. (  
  42. select name,chengji yuwen,'0' shuxue from fzq  
  43. where kecheng='yuwen' union  
  44. select name,'0' yuwen,chengji  shuxue  
  45. from fzq  
  46. where kecheng='shuxue'  
  47. ) aaa  
  48. group BY name;  
  49.   
  50. /*执行结果: 
  51. NAME       YUWEN                  SHUXUE                 
  52. ---------- ---------------------- ---------------------- 
  53. a          80                     70                     
  54. b          40                     100                    
  55. c          90                     92 
  56. */  
  57. /* 
  58. 其次是用case.这种方法代码比较短.适合列值很多的情况. 
  59. */  
  60.   
  61. select name, sum(case kecheng when 'yuwen' then chengji end) yuwen,  
  62.              sum(case kecheng  when 'shuxue' then chengji  end) shuxue  
  63. from fzq  
  64. group by name;  
  65.   
  66. /*执行结果: 
  67. NAME       YUWEN                  SHUXUE                 
  68. ---------- ---------------------- ---------------------- 
  69. a          80                     70                     
  70. b          40                     100                    
  71. c          90                     92 
  72. 所有例子在oracle中测试,sql server没有测试,请根据实际情况修改 
  73.  
  74. 如果有更好的方法,欢迎交流. 
  75. */  





横表和纵表  

 

 

第一张图就是横表,一行表示了一个实体记录,这就是我们传统的设计表的形式  

第二张图就是纵表,他的一行记录,是用于表示某个学生的属性名和属性值对应关系,像这边有两个属性(名字和性别),在纵表中就要用两条记录来表示一个学生。  

从上面可以观察出,横表的好处是清晰可见,一目了然,但是有一个弊端,如果现在要把这个表加一个字段,那么就必须重建表结构。对于这种情况,在纵表中只需要添加一条记录,就可以添加一个字段,所消耗的代价远比横表小,但是纵表的对于数据描述不是很清晰,而且会造成数据库数量很多,两者利弊在于此。所以,应该把不容易改动表结构的设计成横表,把容易经常改动不确定的表结构设计成纵表。  

在实际开发中,经常需要互相转换横表和纵表的形式,这里贴个从纵表数据转成横表显示的形式。  

纵表转横表  

Sql代码    收藏代码
  1. Select student_no,  
  2.         max(decode(field_name,'student_name',field_value)) As student_name,  
  3.         max(decode(field_name,'student_sex',field_value )) As student_sex  
  4.     From cuc_student_y Group By student_no;  

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值