sql - 如何将包体和规范导入/导出到 .sql 或 .pkb 文件中
问题描述
我需要仅使用 sql plus 命令将包主体/规范导入/导出到 .sql 或 .pkb 文件中。
我尝试执行标准选择,但这仅在控制台中显示,但我需要修改文件。
我也需要做相反的事情,即将一个 .sql/.pks/.pkb 文件导入数据库以应用更改。
解决方案
如果您想使用 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>
推荐阅读
- python - 在python变量中添加NaN?
- c# - MongoDB C# 驱动程序:展平对象
- laravel - 在 laravel 中提交文件时,我收到请求太大错误 413
- laravel - 在 Laravel 7 中如何按角色排序-> 名称?
- python - 路径中需要 Python Selenium geckodriver
- unity3d - Unity UI 文本不显示?
- python - 尝试在 SSH 服务器上运行命令时无法从 python 脚本获取输出
- opencv - OpenCV - 确定手腕的位置
- ios - 带参数和不带参数的闭包语法
- php - 使用 CodeIgniter 备份 MySQL 数据库为每个表返回单个查询