(一)使用db2move导出全部数据
db2move是一个集成式的数据移动工具,它支持导出(export)、导入(import)、装入(load)三种操作方式。其实db2move的这三种工作方式分别是通过简单使用db2 export, db2 import, db2 load指令来完成的。
此部分仅仅介绍其export功能,import和load将在稍后的部分介绍。使用db2move导出的数据文件格式是IXF。
建立并进入数据存放目录:
mkdir/home/backup/mydata
cd /home/backup/mydata
导出指定的数据库中的全部数据:
$ db2move testdb export –u db2inst1 –p thepasswd
说明:
1,这将会把数据库testdb中的全部数据提取到当前目录(/home/backup/mydata)中。每个表的内容都存储在一个.ixf文件中,每个.ixf文件都有一个与之相对应的.msg文件,.msg文件是描述从表中导出数据时的信息的。另外还有两个文件,db2move.lst用来记录.ixf文件、.msg文件与表的一一对应关系,EXPORT.out记录的是导出数据时的屏幕输出。
2,有关db2move指令更多的细节,请直接执行该指令,将会打印出其帮助信息。
(二)使用db2move导入(import)数据
以db2inst1用户身份登录到Host 2。
创建数据库mytestdb:
db2db2=>createdatabasemytestdbon‘/home/db2inst1′usingcodesetUTF−8territoryCNdb2=>connecttomytestdbuserdb2inst1usingthepasswd创建一个pagesize为16K的bufferpool,名为mybigpool:db2=>createbufferpoolmybigpoolimmediatesize1000pagesize16K创建一个tablespace使用上面创建的bufferpool,名为mybigspace:db2=>createregulartablespacemybigspacepagesize16Kmanagedbysystemusing(‘/home/db2inst1/db2inst1/NODE0000/SQL00004/SQLT0003.0′)extentsize16overhead12.67prefetchsize16transferrate0.18bufferpoolmybigpooldroppedtablerecoveryoff注:extentsize,overhead,prefetchsize,transferrate这几个参数值与所使用的服务器有关,我这里使用的值是基于普通的、使用SCSI硬盘的PC服务器的。完成空库的创建:db2=>commitworkdb2=>connectresetdb2=>terminate导入(import)数据:使用import方式不需要先建表结构,即,准备好一个空库就行了。这一点与load方式不一样,load方式需要先建立表结构。我将从Host1上导出的全部数据文件(位于Host1的/home/backup/mydata下)复制到Host2下某个目录下,假定为/home/movedata
cd /home/movedata
$ db2move mytestdb import –u db2inst1 –p thepasswd
此时屏幕上会显示有关导入数据的信息。
存在的问题:
db2move import方式只能导入“普通”的表,如果表中存在自增长的IDENTITY列,那么使用db2move import时,会出错。这是因为,如果IDENTITY列创建表的时候都是定义成always的话,那么在导入数据的时候该列数据是不能被赋值的,而是应该由系统生成,使用db2move无法导入这样的表。对于这种含有IDENTITY列的表,只能使用db2 import指令来进行导入,相关的参数是IDENTITYIGNORE,IDENTITYMISSING。我将在下一部分给出具体的指令操作。
一句题外话:
如果需要实现唯一主键,可以不必使用IDENTITY列,改而使用sequence,这样比较便于维护和管理。
注意点:
mybigspace可能要根据实际情况设值