상세 컨텐츠

본문 제목

Select 한 데이터를 세로가 아닌 가로로 보여주는 SQL

DataBase/Oracle

by 탑~! 2014. 4. 1. 15:39

본문

create or replace procedure print_table( p_query in varchar2 )

AUTHID CURRENT_USER

is

    l_theCursor     integer default dbms_sql.open_cursor;

    l_columnValue   varchar2(4000);

    l_status        integer;

    l_descTbl       dbms_sql.desc_tab;

    l_colCnt        number;

begin

    execute immediate

    'alter session set 

        nls_date_format=''dd-mon-yyyy hh24:mi:ss'' ';


    dbms_sql.parse(  l_theCursor,  p_query, dbms_sql.native );

    dbms_sql.describe_columns

    ( l_theCursor, l_colCnt, l_descTbl );


    for i in 1 .. l_colCnt loop

        dbms_sql.define_column

        (l_theCursor, i, l_columnValue, 4000);

    end loop;


    l_status := dbms_sql.execute(l_theCursor);


    while ( dbms_sql.fetch_rows(l_theCursor) > 0 ) loop

        for i in 1 .. l_colCnt loop

            dbms_sql.column_value

            ( l_theCursor, i, l_columnValue );

            dbms_output.put_line

            ( rpad( l_descTbl(i).col_name, 30 )

              || ': ' || 

              l_columnValue );

        end loop;

        dbms_output.put_line( '-----------------' );

    end loop;

    execute immediate

        'alter session set nls_date_format=''dd-MON-rr'' ';

exception

    when others then

      execute immediate

          'alter session set nls_date_format=''dd-MON-rr'' ';

      raise;

end;

/

 

출처: http://tong.nate.com/lhs0806/30638676



관련글 더보기