首页 > 数据库 > DB2 > 正文

我用DB2这些年(四)

2020-03-09 22:29:32
字体:
来源:转载
供稿:网友

续:恢复数据库

最近不断地有人问我怎么在命令行下面恢复数据库,我给每个人都进行了比较详细的说明;后来感觉这样的事情还是写出来比较好一些,于是就有了想写关于这个东西的念头。我想还是从讲故事开始把。。。。。。

那是一个冬天,很冷很冷的那种。当时做一个项目,采用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;
国内最大的酷站演示中心!
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表