首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > oracle >

oracle 10g 行转列(动态列),该如何处理

2013-04-02 
oracle 10g 行转列(动态列)如题,大家一般都是怎么解决这个问题的?[解决办法]以前写的动态行转列其实行列转

oracle 10g 行转列(动态列)
如题,大家一般都是怎么解决这个问题的?
[解决办法]
以前写的  动态行转列  其实行列转换类型都差不多

create or replace procedure p1 is
Cursor cursor is select t.column_name cn
  from user_col_comments t
  where t.table_name = upper('t1') and t.column_name <> 'y';
  sqlstr varchar2(4000);
begin
  for c_name in cursor loop 
  begin
  sqlstr := sqlstr + ' select '
[解决办法]
c_name.cn
[解决办法]
',decode(t1.y,2009,(select '
[解决办法]
c_name.cn
[解决办法]
' from t1 where y=2009),0) cc from t1 union all ';
  DBMS_OUTPUT.PUT_LINE(sqlstr);
  end;
  end loop;
  --EXECUTE IMMEDIATE (sqlstr);
end p1;

热点排行