본문 바로가기

빅데이터과정/WORKSHOP 1

#19_140709_WSHOP_깔끔하게 출력하는법

728x90



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);
    dbms_output.put_line( '-----------------' );
    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;
/



  • 지저분하게 나오는 출력값을 깔끔하게 보고 싶다면 위의 프로시져를 만든 후에 아래와 같이 수행한다



SQL> exec print_table('select * from v$controlfile');


'빅데이터과정 > WORKSHOP 1 ' 카테고리의 다른 글

#19_140709_WSHOP_TABLESPACE  (0) 2014.07.15
#19_140709_WSHOP_DYNAMIC PERFORMANCE  (0) 2014.07.15
#19_140709_WSHOP_장애복구  (0) 2014.07.15
#19_140709_WSHOP_SHUTDOWN 옵션  (0) 2014.07.15
#17_140708_WSHOP_INSTANCE  (0) 2014.07.15