首页 > 解决方案 > 如何将包体和规范导入/导出到 .sql 或 .pkb 文件中

问题描述

我需要仅使用 sql plus 命令将包主体/规范导入/导出到 .sql 或 .pkb 文件中。

我尝试执行标准选择,但这仅在控制台中显示,但我需要修改文件。

我也需要做相反的事情,即将一个 .sql/.pks/.pkb 文件导入数据库以应用更改。

标签: sqloraclesqlplus

解决方案


如果您想使用 SQL*Plus 来做到这一点,那么 - 正如您被告知的那样 -spool似乎是一个自然的选择。这是一个例子,看看它是否有帮助。

首先,我将创建一个简单的包:

SQL> create or replace package pkg_test as
  2    function f_today return date;
  3  end;
  4  /

Package created.

SQL> create or replace package body pkg_test as
  2    function f_today return date is
  3    begin
  4      return sysdate;
  5    end;
  6  end;
  7  /

Package body created.

SQL> select pkg_test.f_today from dual;

F_TODAY
-------------------
02.09.2019 22:28:56

SQL>

为了创建一个漂亮的输出文件:

  • 应该设置一些 SQL*Plus设置
  • 当你想导出一个包时,我们会查询user_source
  • 它不包含create (or replace)所以我将单独选择它
  • 终止斜线也是如此/

所有这些都将存储在一个.SQL文件中。如果您直接运行这些命令,导出文件也将包含select语句,这是您要避免的。

Spool.sql文件:

set heading off
set feedback off
set pagesize 0
set termout off
set trimout on
set trimspool on
set recsep off
set linesize 120

spool pkg_test.sql

select 'create or replace' from dual;
select text from user_source
  where name = 'PKG_TEST'
    and type = 'PACKAGE'
order by line;
select '/' from dual;

select 'create or replace' from dual;
select text from user_source
  where name = 'PKG_TEST'
    and type = 'PACKAGE BODY'
order by line;
select '/' from dual;

spool off;

让我们运行它;由于所有这些SET命令,您实际上什么都看不到;提示将SQL>是全部,就好像什么都没发生一样:

SQL> @spool
SQL>

但是,如果您检查文件中写入的pkg_test.sql内容,您将看到该包:

SQL> $type pkg_test.sql
create or replace
package pkg_test as
  function f_today return date;
end;
/
create or replace
package body pkg_test as
  function f_today return date is
  begin
    return sysdate;
  end;
end;
/

SQL>

看起来不错,所以 - 回答你的第二个问题(如何将其导入回来) - 只需运行它。我将首先退出 SQL*Plus;否则 - 再次因为SET命令 - 你不会看到任何东西:

SQL> exit
Disconnected from Oracle Database 11g Express Edition Release 11.2.0.2.0 - 64bit Production

C:\Users\lf>sqlplus scott/tiger

SQL*Plus: Release 11.2.0.2.0 Production on Pon Ruj 2 22:36:06 2019

Copyright (c) 1982, 2014, Oracle.  All rights reserved.


Connected to:
Oracle Database 11g Express Edition Release 11.2.0.2.0 - 64bit Production

SQL> @pkg_test

Package created.


Package body created.

SQL>

推荐阅读