动态的行列转换
11G 可以考虑用PIVOT
http://www.cnblogs.com/zlja/archive/2011/12/10/2449515.html
7、动态行转不定列
----------------新建测试表
CREATE TABLE TEST(
WL VARCHAR2(10),
XYSL INTEGER,
XYCK VARCHAR2(10),
XCLCK VARCHAR2(10),
XCLCKSL INTEGER,
PC INTEGER
);
----------------第一部分测试数据
INSERT INTO TEST VALUES('A1', 2, 'C1', 'C1' , 20, 123);
INSERT INTO TEST VALUES('A1', 2, 'C1', 'C2' , 30, 111);
INSERT INTO TEST VALUES('A1', 2, 'C1', 'C2' , 20, 222);
INSERT INTO TEST VALUES('A1', 2, 'C1', 'C3' , 10, 211);
INSERT INTO TEST VALUES('A2', 3, 'C4', 'C1' , 40, 321);
INSERT INTO TEST VALUES('A2', 3, 'C4', 'C4' , 50, 222);
INSERT INTO TEST VALUES('A2', 3, 'C4', 'C4' , 60, 333);
INSERT INTO TEST VALUES('A2', 3, 'C4', 'C5' , 70, 223);
COMMIT;
----------------行转列存储过程
CREATE OR REPLACE PROCEDURE P_TEST IS
V_SQL VARCHAR2(2000);
CURSOR CURSOR_1 IS
SELECT DISTINCT T.XCLCK FROM TEST T ORDER BY XCLCK;
BEGIN
V_SQL := 'SELECT WL,XYSL,XYCK';
FOR V_XCLCK IN CURSOR_1 LOOP
V_SQL := V_SQL
[解决办法]
','
[解决办法]
'SUM(DECODE(XCLCK,'''
[解决办法]
V_XCLCK.XCLCK
[解决办法]
''',XCLCKSL,0)) AS '
[解决办法]
V_XCLCK.XCLCK;
END LOOP;
V_SQL := V_SQL
[解决办法]
' FROM TEST GROUP BY WL,XYSL,XYCK ORDER BY WL,XYSL,XYCK';
--DBMS_OUTPUT.PUT_LINE(V_SQL);
V_SQL := 'CREATE OR REPLACE VIEW RESULT AS '
[解决办法]
V_SQL;
--DBMS_OUTPUT.PUT_LINE(V_SQL);
EXECUTE IMMEDIATE V_SQL;
END;
----------------执行存储过程
BEGIN
P_TEST;
END;
----------------查看结果
SELECT * FROM RESULT;
----------------第二部分测试数据
INSERT INTO TEST VALUES('A1', 2, 'C1', 'C6' , 20, 124);
INSERT INTO TEST VALUES('A2', 2, 'C1', 'C7' , 30, 121);
INSERT INTO TEST VALUES('A3', 2, 'C1', 'C8' , 20, 322);
COMMIT;
----------------执行存储过程
BEGIN
P_TEST;
END;
----------------查看结果
SELECT * FROM RESULT;
with t as(
select 1 part,1 zc,0 cnt from dual
union all
select 1 part,2 zc,1 cnt from dual
union all
select 1 part,3 zc,1 cnt from dual
union all
select 2 part,3 zc,2 cnt from dual
union all
select 2 part,2 zc,1 cnt from dual)
SELECT part,sum(DECODE(zc,1,cnt,NULL)) zc1,
sum(DECODE(zc,2,cnt,NULL)) zc2,
sum(DECODE(zc,3,cnt,NULL)) zc3
from t GROUP BY part