如何实现一个功能,将oracle中一个用户下的所有表结构导出到.sql文件中

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/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/7199859/viewspace-263656/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值