动态枢轴 table - sql 开发人员
Dynamic pivot table - sql developer
我试图为动态数据透视创建自己的程序,但它不起作用。
我的程序创建正确,但当我想执行它时,它不起作用。
首先,我尝试了 bluefeet 的程序并且它正在运行。 link 这个问题
Dynamically pivoting a table Oracle
我的程序应该计算 p_key.
列中值的出现次数
也许有人知道为什么我的程序不起作用。
我的代码 table
create table aa_tabela (
C_ID number(3,0),
gcm number(1,0),
p_key varchar2(30),
p_count number(6,0));
我插入了几个值
INSERT ALL
INTO aa_tabela (C_ID, gcm, p_key, p_count )
VALUES (1, 7, 'Data Mining', 2)
INTO aa_tabela (C_ID, gcm, p_key, p_count )
VALUES (2, 5, 'Data Mining', 3)
INTO aa_tabela (C_ID, gcm, p_key, p_count )
VALUES (3, 3, 'Reporting', 1)
INTO aa_tabela (C_ID, gcm, p_key, p_count )
VALUES (4, 3, 'Olap', 5)
INTO aa_tabela (C_ID, gcm, p_key, p_count )
VALUES (5, 1, 'Reporting', 4)
SELECT * FROM dual;
我的静态 PIVOT table 正在工作:
SELECT GCM,
SUM(case when p_key = 'Data Mining' then p_count end) AS Data_Mining,
SUM(case when p_key = 'Reporting' then p_count end) AS Reporting,
SUM(case when p_key = 'Olap' then p_count end) AS OLAP
from aa_tabela
group by gcm
order by gcm desc;
结果:
|GCM | DATA_MINING | REPORTING | OLAP |
| 7 | 2 | | |
| 5 | 3 | | |
| 3 | | 1 | 5 |
| 1 | | 4 | |
我的动态数据透视程序创建正确:
CREATE OR REPLACE procedure test_abc(p_cursor in out sys_refcursor)
AS
sql_query long := 'select gcm ';
BEGIN
for x in (select distinct p_key from aa_tabela order by 1)
loop
sql_query := sql_query ||
' , sum(case when p_key = '''||x.p_key||''' then p_count end) as '||x.p_key;
dbms_output.put_line(sql_query);
end loop;
sql_query := sql_query || ' from aa_tabela group by gcm';
open p_cursor for sql_query;
END;
/
程序 TEST_ABC 编译
我通过以下代码执行程序:
variable x refcursor
exec test_abc(:x);
print x
错误信息:
Error starting at line : 215 in command -
exec test_abc(:x)
Error report -
ORA-00923: FROM keyword not found where expected
ORA-06512: at "MAGDA.TEST_ABC", line 16
ORA-06512: at line 1
00923. 00000 - "FROM keyword not found where expected"
您收到错误消息,因为其中一个值是 "Data Mining"。在您的程序中,它被转换为列别名,如 as Data Mining
。
您需要在第 9 行将 space 更改为下划线或添加引号:
' , sum(case when p_key = '''||x.p_key||''' then p_count end) as "'||x.p_key||'"';
我试图为动态数据透视创建自己的程序,但它不起作用。 我的程序创建正确,但当我想执行它时,它不起作用。 首先,我尝试了 bluefeet 的程序并且它正在运行。 link 这个问题 Dynamically pivoting a table Oracle
我的程序应该计算 p_key.
列中值的出现次数也许有人知道为什么我的程序不起作用。
我的代码 table
create table aa_tabela (
C_ID number(3,0),
gcm number(1,0),
p_key varchar2(30),
p_count number(6,0));
我插入了几个值
INSERT ALL
INTO aa_tabela (C_ID, gcm, p_key, p_count )
VALUES (1, 7, 'Data Mining', 2)
INTO aa_tabela (C_ID, gcm, p_key, p_count )
VALUES (2, 5, 'Data Mining', 3)
INTO aa_tabela (C_ID, gcm, p_key, p_count )
VALUES (3, 3, 'Reporting', 1)
INTO aa_tabela (C_ID, gcm, p_key, p_count )
VALUES (4, 3, 'Olap', 5)
INTO aa_tabela (C_ID, gcm, p_key, p_count )
VALUES (5, 1, 'Reporting', 4)
SELECT * FROM dual;
我的静态 PIVOT table 正在工作:
SELECT GCM,
SUM(case when p_key = 'Data Mining' then p_count end) AS Data_Mining,
SUM(case when p_key = 'Reporting' then p_count end) AS Reporting,
SUM(case when p_key = 'Olap' then p_count end) AS OLAP
from aa_tabela
group by gcm
order by gcm desc;
结果:
|GCM | DATA_MINING | REPORTING | OLAP |
| 7 | 2 | | |
| 5 | 3 | | |
| 3 | | 1 | 5 |
| 1 | | 4 | |
我的动态数据透视程序创建正确:
CREATE OR REPLACE procedure test_abc(p_cursor in out sys_refcursor)
AS
sql_query long := 'select gcm ';
BEGIN
for x in (select distinct p_key from aa_tabela order by 1)
loop
sql_query := sql_query ||
' , sum(case when p_key = '''||x.p_key||''' then p_count end) as '||x.p_key;
dbms_output.put_line(sql_query);
end loop;
sql_query := sql_query || ' from aa_tabela group by gcm';
open p_cursor for sql_query;
END;
/ 程序 TEST_ABC 编译
我通过以下代码执行程序:
variable x refcursor
exec test_abc(:x);
print x
错误信息:
Error starting at line : 215 in command -
exec test_abc(:x)
Error report -
ORA-00923: FROM keyword not found where expected
ORA-06512: at "MAGDA.TEST_ABC", line 16
ORA-06512: at line 1
00923. 00000 - "FROM keyword not found where expected"
您收到错误消息,因为其中一个值是 "Data Mining"。在您的程序中,它被转换为列别名,如 as Data Mining
。
您需要在第 9 行将 space 更改为下划线或添加引号:
' , sum(case when p_key = '''||x.p_key||''' then p_count end) as "'||x.p_key||'"';