Oracle
 sql >> Base de Dados >  >> RDS >> Oracle

Como converter linhas em coluna na tabela Oracle


Recentemente, encontrei uma tabela oracle que possui 50 colunas e preciso analisar cada coluna para a linha específica. Foi difícil visualizar essas 50 colunas nas linhas, então criei abaixo do bloco PLSQL para converter as linhas em coluna. Isso leva o nome da tabela como entrada e imprime uma linha no formato de coluna
set serveroutput on
declare
colname varchar2(100);
sql_str VARCHAR2(200);
col_value varchar(100);
--------- !!!! Carefully change this select state ment !!! --------------
cursor cur2 is select COLUMN_NAME from dba_tab_columns where TABLE_NAME='&1';
begin
for rec1 in cur2
loop
colname :=rec1.COLUMN_NAME;
sql_str:='select '|| colname ||' from apps.&&1 where rownum< 2';
EXECUTE IMMEDIATE sql_str into col_value;
dbms_output.put_line ( colname ||':'||col_value );
end loop;
end;
/