当前位置: 代码迷 >> J2EE >> oracle sql 有关问题
  详细解决方案

oracle sql 有关问题

热度:4376   发布时间:2013-02-25 21:38:50.0
oracle sql 问题
1.这是 user_name  表 
year??month amount
 1991?? 1???? 1.1
 1991?? 2???? 1.2
 1991?? 3???? 1.3
 1991?? 4???? 1.4
 1992?? 1???? 2.1
 1992?? 2???? 2.2
 1992?? 3???? 2.3
 1992?? 4???? 2.4


写一个sql (要求 用 lead over  这些 分析 函数 为了 提高 效率)

实现 下面的 效果 

 year m1??m2??m3??m4
 1991 1.1 1.2 1.3 1.4
 1992 2.1 2.2 2.3 2.4 

oracle sql
http://wenku.baidu.com/view/6694a7225901020207409c5dhttp://wenku.baidu.com/view/6694a7225901020207409c5d自己研究语法去
with temp as
(
select 1991 year,1 month,1.1 amount from dual 
union all
select 1991 year,2 month,1.2 amount from dual
union all
select 1991 year,3 month,1.3 amount from dual
union all
select 1991 year,4 month,1.4 amount from dual
union all
select 1992 year,1 month,2.1 amount from dual
union all
select 1992 year,2 month,2.2 amount from dual
union all
select 1992 year,3 month,2.3 amount from dual
union all
select 1992 year,4 month,2.4 amount from dual

select * from temp
PIVOT (SUM(amount) FOR month IN  (1 as m1,2 as m2,3 as m3,4 as m4) )


      YEAR         M1         M2         M3         M4
---------- ---------- ---------- ---------- ----------
      1991        1.1        1.2        1.3        1.4
      1992        2.1        2.2        2.3        2.4

11G的行转列可以用这个方式
如果是10g还是老实的用decode吧
为啥要用分析函数,谁告诉你用了就能提高效率?非要用sql其实不是很好的方法,
可以先用 group by 月份,
然后程序里就好做了!
这种问题我们都碰到 过!11G的行转列可以用这个方式
如果是10g还是老实的用decode吧
为啥要用分析函数,谁告诉你用了就能提高效率? 
  相关解决方案