Oracle批量导出存储过程(保持每个存储过程独立)

如有A,B,C三个存储过程希望被导出,导出时还是保持A.sql,B.sql,C.sql而不是全部导到一个text.sql当中。存储过程或者shell方式都可以... 如有A,B,C三个存储过程希望被导出,导出时还是保持A.sql,B.sql,C.sql而不是全部导到一个text.sql当中。存储过程或者shell方式都可以 展开
 我来答
badkano
2019-03-09 · 知道合伙人体育行家
badkano
知道合伙人体育行家
采纳数:144776 获赞数:885368
团长

向TA提问 私信TA
展开全部

略微复杂,需要存储过程实现。

1、创建输出路径,比如你要在d盘test目录下输出,你就先在d盘根目录下建立一个test的目录。

2、sqlplus下以sysdba登录,执行以下语句

create or replace directory TMP as 'd:\test';
 
grant read,write on directory TMP to scott; --比如我用的scott用户
 
alter system set utl_file_dir='d:\test' scope=spfile;

3、以上步骤执行完,需要重启数据库。

4、创建一个存储过程,代码如下(基本是不用改动,原封复制即可):

CREATE OR REPLACE PROCEDURE SP_OUTPUT_PROCEDURE is
  file_handle     utl_file.file_type;
  Write_content   VARCHAR2(1024);
  Write_file_name VARCHAR2(50);
  v_name          varchar2(50);
  v_text          varchar2(2000);
  cursor cur_procedure_name is
    select distinct name from user_source where type = 'PROCEDURE';
  cursor cur_sp_out is
    select t.text
      from (select 0 line, 'CREATE OR REPLACE ' text
              from dual
            union
            select line, text
              from user_source
             where type = 'PROCEDURE'
               and name = v_name) t
     order by line;
begin
  open cur_procedure_name;
  loop
    fetch cur_procedure_name
      into v_name;
    exit when cur_procedure_name%notfound;
    write_file_name := v_name || '.txt';
    open cur_sp_out;
    loop
      fetch cur_sp_out
        into v_text;
      exit when cur_sp_out%notfound;
      file_handle   := utl_file.fopen('TMP', write_file_name, 'a');
      write_content := v_text;
      --write file
      IF utl_file.is_open(file_handle) THEN
        utl_file.put_line(file_handle, write_content);
      END IF;
      --close file
      utl_file.fclose(file_handle);
    end loop;
    close cur_sp_out;
  end loop;
  close cur_procedure_name;
end;

5、创建完毕执行存储过程,这个就不赘述了,执行完毕后,你会发现d盘test目录下的文件名就是以存储过程名命名的txt文件,如图:

6、里边内容(就是存储过程创建时的代码,可能排版看着难看点,但是不影响使用):

追问
请问第31行里的a代表什么?
光点科技
2023-08-15 广告
通常情况下,我们会按照结构模型把系统产生的数据分为三种类型:结构化数据、半结构化数据和非结构化数据。结构化数据,即行数据,是存储在数据库里,可以用二维表结构来逻辑表达实现的数据。最常见的就是数字数据和文本数据,它们可以某种标准格式存在于文件... 点击进入详情页
本回答由光点科技提供
百度网友443cea2
2019-03-02 · TA获得超过370个赞
知道小有建树答主
回答量:832
采纳率:73%
帮助的人:258万
展开全部
用plsql到出,十分方便
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式