Jon
作者Jon·2011-02-27 22:25
数据库管理员·东南融通

提取 DB2 数据库中所有存储过程的创建语句

字数 1034阅读 2804评论 0赞 0
介绍获取 DB2 v8 数据库中所有存储过程创建语句的三种方法。

产品:DB2 UDB 平台:跨平台 版本:v8

如果 DB2 v8 的用户需要提取数据库所有存储过程的定义,即用 CREATE PROCEDURE 创建存储过程的语句,以便保留或在其它数据库环境下重新创建这些存储过程,可尝试如下介绍的三种方法:

方法一:
从 DB2 的目录表 SYSCAT.ROUTINES 中选取:

在 SYSCAT.ROUTINES 系统目录表中,有一个名为 TEXT 的字段,其数据类型定义为 CLOB,长度为 2M(2097152 个字节),用于存放存储过程的创建语句。为得到全部存储过程的定义,可使用类似如下 SELECT 语句,并将定义输出到一个文件中。

DB2 SELECT CHAR(ROUTINESCHEMA,20), CHAR(ROUTINENAME,20), TEXT FROM SYSCAT.ROUTINES > <输出文件名>

选用这种方法有一点要注意的是,如果创建语句超过 2097152 个字节(2M)时将被截断,对于较大的语句,可能无法获得完整的创建语句。

方法二:
对于 v8.2 之后的 DB2,DB2LOOK 命令的 -e 选项中增加了对存储过程的创建语句的提取,用户通过执行:

db2look -d <数据库名> -e -o <输出文件名>

在命令结束后的输出文件中找到“存储过程的 DDL 语句”段,从而获得创建所有存储过程的语句。

方法三:
通过 GET ROUTINE 命令来完成:

由于 GET ROUTINE 只能在已知存储过程名称后,对单个存储过程进行,因此需要分成两个步骤来完成:

1)获取所有存储过程的名称:

DB2 SELECT CHAR(ROUTINESCHEMA,20) AS SCHEMA, CHAR(ROUTINENAME,20) AS NAME FROM SYSCAT.ROUTINES WHERE SUBSTR(VARCHAR(TEXT),1,16) = 'CREATE PROCEDURE' > <输出文件名>

2. 根据输出文件中存储过程的名称,分别对每个存储过程执行如下操作,以便将完整的创建语句输出到指定文件中:

DB2 GET ROUTINE INTO <输出文件名> FROM PROCEDURE <存储过程模式名>.<存储过程名>

如果觉得我的文章对您有用,请点赞。您的支持将鼓励我继续创作!

0

添加新评论0 条评论

Ctrl+Enter 发表

作者其他文章

相关文章

相关问题

相关资料

X社区推广