读书人

动态的队列转换

发布时间: 2013-08-06 16:47:25 作者: rapoo

动态的行列转换



如图,想把形式改为
部门ID 职称ID1 职称ID2 职称ID3 职称ID4 职称ID5
1 0 1 1 0 0
2 .
这样的形式,其中部门与职称都是动态的

还有对于group by的不显示Null也是非常纠结,用nvl不行,查了下说是要用外连接?

希望大家能帮帮忙 SQL 行列转换
[解决办法]
11G 可以考虑用PIVOT
http://www.cnblogs.com/zlja/archive/2011/12/10/2449515.html

[解决办法]
部门与职称都是动态的话,一个sql根本搞不定的。

需要用存储过程。。

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

这样可以了

读书人网 >oracle

热点推荐