如何實現一個功能,將oracle中一個使用者下的所有表結構匯出到.sql檔案中

paulyibinyi發表於2008-05-09

pub上的一個案例 

http://www.itpub.net/thread-985145-1-1.html

 

1.用system使用者建立路徑 utl_dir用於存放檔案

SQL> create or replace directory UTL_DIR as 'd:\dba';
SQL> grant write on directory UTL_DIR to public;
SQL> grant read on directory UTL_DIR to public;


2.在hr使用者建立儲存過程 匯出單個表結構
create or replace procedure p_exportDLL(p_table_name varchar2,p_filename varchar2) is
begin

  declare
    l_file     UTL_FILE.FILE_TYPE;
    l_buffer   VARCHAR2(1000);
    l_amount   BINARY_INTEGER := 100;
    l_pos      INTEGER := 1;
    l_clob     clob;
    l_clob_len INTEGER;
  begin
    select dbms_metadata.get_ddl('TABLE',p_table_name )||';' into l_clob from dual;
    l_clob_len := DBMS_LOB.GETLENGTH(l_clob);
    l_file     := UTL_FILE.FOPEN('UTL_DIR', p_filename||'.sql', 'a', 1000);
   
   

    WHILE l_pos < l_clob_len LOOP
      DBMS_LOB.READ(l_clob, l_amount, l_pos, l_buffer);
      UTL_FILE.put(l_file, l_buffer);
      l_pos := l_pos + l_amount;
    END LOOP;
    UTL_FILE.FCLOSE(l_file);
    --if @@error
  end;
end p_exportDLL;


3.匯出所有表的結構
CREATE OR REPLACE PROCEDURE p_whole AS
BEGIN
  FOR x IN (SELECT table_name FROM user_tables) LOOP
       p_exportDLL(x.table_name,'paul');
  END LOOP;
END  p_whole;

驗證
SQLbegin


  2    
-- Call the procedure


  3    p_whole
;


  
4  end;


  
5  /



 

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/7199859/viewspace-263656/,如需轉載,請註明出處,否則將追究法律責任。

相關文章