** 续:恢复数据库 **
最近不断地有人问我怎么在命令行下面恢复数据库,我给每个人都进行了比较详细的说明;后来感觉这样的事情还是写出来比较好一些,于是就有了想写关于这个东西的念头。我想还是从讲故事开始把。。。。。。
那是一个冬天,很冷很冷的那种。当时做一个项目,采用 IBM RS6000 小型机作为数据库的服务器,当时是第一次接触这种机器,感觉什么东西都很新鲜。在摆弄了几天之后我真正认识到学会使用 CPL 环境管理数据库是多么的关键,因为我把系统玩得不正常了, DB2cc 在那上面启动不起来了(后来经过查验是 AIX 系统环境变量的问题)。当时我一下子就蒙到那里了,因为我刚做了备份后 Drop 了数据库准备重新恢复到另外一个地方的;后面开发还要用呢。这时候出问题可真是要命啊 ~~ 这个时候最需要的就是冷静,我回想起当时备份使用的命令行环境,肯定可以用它来恢复数据库的,但是怎么去重定向那些表空间呢?问题就在这里,原来都是用图形界面来完成的根本就没有考虑用命令行来做,弄得现在这么狼狈地。哎!早知如此,何必当初阿!
想想还是从信息中心找下把,不过运气还不错让我给找到了。在 _ Command Reference _ 的 Restore DataBase 章节中有个例子是关于重定向表空间的,于是我照着做了,具体过程如下:
第一步:建立一个新的数据库,在这里需要注意它的字符集,例如:
**_ db2 create db test on /home/db2inst1 using codeset GBK territory zh_CN; _ **
codeset GBK territory zh_CN 就是指定中文字符集的命令字
第二步:将需要恢复的数据库恢复到这个新建的数据库中,在这个命令运行的时候会有一个提示信息,大概得意思就是说你要恢复的数据库正试图覆盖一个数据库,原来数据库的数据将会被覆盖,你可以不管它,选择 Yes 就行,因为那个数据库就是你刚才新建的。
db2 restore db test1 from /home/db2inst1/dbback taken at 20040330073123 into test REDIRECT WITHOUT ROLLING FORWARD;
在这个命令中需要指定待恢复数据库的时间戳, REDIRECT WITHOUT ROLLING FORWARD 的意思是不要前滚。
第三步:重新定向表空间,我在这里使用的是文件型的表空间容器。
在这里需要注意的是你必须事先知道表空间容器的类型和大小。通过 LIST TABLESPACES 命令可以查看到数据库表空间的数量、类型和 ID 。然后通过命令 LIST TABLESPACE CONTAINERS For tablespaceID (在前面命令中显示的 tablespaceID 的值) show detail 查看表空间容器的大小类型和位置,如下所示:
**_Tablespace Containers for Tablespace 0_**
**__**
**_ Container ID = 0_**
**_Name = /home/smith/smith/NODE0000/_**
**_ SQL00001/SQLT0000.0_**
**_Type = Path_**
**_Total pages = 895_**
**_Useable pages = 895_**
**_Accessible = Yes_**
接下来决定需要重定向表空间容器的类型位置和大小。重定向的表空间容器的 size 是不能小于当前值。
**_ db2 = _ ** **_ 〉 set tablespace containers for 4 using (file '/home/db2inst1/ long' 51200); _ **
**_ db2 = _ ** **_ 〉 set tablespace containers for 3 using (file '/home/db2inst1/temp' 51200); _ **
**_ db2 = _ ** **_ 〉 set tablespace containers for 2 using (file '/home/db2inst1/user' 102400); _ **
第四步:正式恢复数据库,打完收工。
**_ db2 => restore db test1 continue; _ **