db2 存储过程迁移方法

大家在迁移数据库时,存储过程一般也要迁移过去,但一般有两个问题:

1. 很多存储过程有先后关系(存储过程调用存储过程),如果存储过程数量少,还能手动操作,如果量大,那真是要疯了。

2. 存储过程过大(行数过多),导致异常

这边有个方法,或许可以解决这个问题。

一. 导出存储过程

EXPORT TO G:/PROCUDURE/procudure.del OF del MODIFIED BY LOBSINFILE

SELECT ‘SET CURRENT SCHEMA ‘||rtrim(procschema)||‘@‘||chr(10)||‘SET CURRENT PATH = SYSIBM,SYSFUN,SYSPROC,‘||rtrim(procschema)||‘ @‘||chr(10)||text||chr(10)||‘@‘||chr(10)

FROM syscat.procedures WHERE PROCSCHEMA  = ‘ILS‘ ORDER BY create_time ;

执行以上导出语句,则是把schema为ils下面的存储过程导出为文件,因为有ORDER BY create_time,所以导出的顺序也是按照原有存储过程的顺序建立的。

执行完了,应该在G:/PROCUDURE看到两个文件

1. procudure.del

2. procudure.del.001.lob

如图:

会出现procudure.del.001.lob这个文件,因为我这边有存储过程太大(使用MODIFIED BY LOBSINFILE),所以导出为lob文件,这样不容易出错。

二. 导入存储过程

下一步当然是在其他db下面导入存储过程啦:

1. 命令行下进入到G:/PROCUDURE

2. 连接到要导入的db:  connect to ilsdb user xxx用户 using  xxx密码

3. db2 [email protected] -vf procudure.del.001.lob

ok,顺便看看log,有没有报错。有报错,在执行一次(虽然是按照创建时间排序的,但不能保证有人后期修改过父存储过程,导致创建时间不对)。

导入过程见图:

打开后输入以下命令

时间: 2024-10-07 05:16:19

db2 存储过程迁移方法的相关文章

db2存储过程迁移

一.导出存储过程 EXPORT TO D:/PROCUDURE/procudure.del OF del MODIFIED BY LOBSINFILE SELECT 'SET CURRENT SCHEMA '||rtrim(procschema)||'@'||chr(10)||'SET CURRENT PATH = SYSIBM,SYSFUN,SYSPROC,'||rtrim(procschema)||' @'||chr(10)||text||chr(10)||'@'||chr(10)FROM

数据库 SQL Server 到 MySQL 迁移方法总结

最近接手一起老项目数据库 SQL Server 到 MySQL 的迁移.因此迁移前进行了一些调查和总结.下面是一些 SQL Server 到 MySQL 的迁移方法. 1. 使用 SQLyog 迁移 具体方法可以参加:http://www.cnblogs.com/gaizai/p/3237907.html 优点:该迁移方法很简单,灵活,迁移时,可以进行字段的修改,比如在sql server中原来是datetime,然后迁移到mysql时你可以配置成timestamp: 成功率很高: 缺点:迁移很

Ubuntu Server搭建svn服务以及迁移方法【转】

转自:http://www.linuxidc.com/Linux/2013-05/84693.htm Ubuntu Server搭建svn服务以及迁移方法 采用apache+svn,http访问方式. 先确定安装了apache,没有安装则用以下命令: sudo apt-get install apache2 然后安装subversion及svn-apache连接库: sudo apt-get install subversion sudo apt-get install libapache2-s

[Windows Server 2008] MySQL单数据库迁移方法

★ 欢迎来到[护卫神·V课堂],网站地址:http://v.huweishen.com ★ 护卫神·V课堂 是护卫神旗下专业提供服务器教学视频的网站,每周更新视频. ★ 本节我们将带领大家:MySQL数据库迁移方法 注意:此方法只适用于MyISAM模式的数据库(如护卫神·PHP套件):InnoDB不适合本方法. 本节主要讲述单个数据库迁移:如果是MySQL整体迁移,请查看我站其他视频. 操作流程:先在旧服务器上备份数据库,然后在新服务器创建数据库,再恢复数据. 1.查找数据库路径    打开[服

DB2 存储过程语法(翻译)

语法说明 1.procedure-name: 存储过程的名字,在同一个数据库的同一模式下,不能存在存储过程名相同参数数目相同的存储过程,即使参数的类型不同也不行. 2.(IN | OUT | INOUT parameter-name data-type,...) :传入参数     IN:输入参数 OUT:输出参数 INOUT:作为输入输出参数     parameter-name:参数名字,在此存储过程中唯一的标识符. data-type:参数类型,可以接收SQL类型和创建的表.不支持LONG

C#调用Oracle存储过程的方法

本文实例讲述了C#调用Oracle存储过程的方法.分享给大家供大家参考.具体实现方法如下: Oracle数据库代码如下: 代码如下: create or replace procedure proce_test(paramin in varchar2,paramout out varchar2,paraminout in out varchar2) as varparam varchar2(28); begin varparam:=paramin; paramout:=varparam|| pa

GitLab目录迁移方法

在生产环境上迁移GitLab的目录需要注意一下几点: 1.目录的权限必须为755或者775 2.目录的用户和用户组必须为git:git 3.如果在深一级的目录下,那么git用户必须添加到上一级目录的账户. 4.很多文章说修改/etc/gitlab/gitlab.rb这个文件里面的git_data_dirsb变量,其实没必要,只需要使用软链接改变原始目录/var/opt/gitlab/git-data更好一些. 迁移方法: 此方法适用于版本:11.4.5+ # 停止服务 gitlab-ctl st

DB2数据库迁移数据到Oracle数据库

刚到公司后,领导交给我个任务:把DB2数据库中的数据导入到Oracle数据库,本人尝试以下方法,挺快的.还要导入db2jcc.jar.db2jcc_license_cu.jar.ojdbc14.jar三个相应的jar包. 数据迁移:1.在DB2数据库中通过以下表查询出表的结构SELECTTABNAME TAB, --表英文名称COLNAME COL, --列名称CASE WHEN TYPENAME='VARCHAR' THEN 'VARCHAR2'WHEN TYPENAME LIKE 'SMAL

db2存储过程报SQL0104N错误

ERROR [42601] [IBM][DB2/LINUXX8664] SQL0104N  An unexpected token "insert" was found following "".  Expected tokens may include:  "<psm_semicolon>". 这种情况是存储过程语法报错,解决方法是注释一段代码,执行存储过程,去测试是哪一段代码语法有问题