DB2数据库和表恢复

DB2数据库和表恢复,第1张

1. 如何恢复误删的表

使用recover dropped table功能即可

要求是: 误删的表建立且数据注入之后,有该数据库备份

通过db2 list history dropped table all for dbname找到误删表的Backup ID以及该表的DDL语句

恢复误删表所在表空间 db2 restore db dbname tablespace(tbspname) taken at xxxx

在前滚中指定误删表 backup id,输出表数据

db2 rollforward db dbname to end of logs tablespace(误删表所在表空间名字) recover dropped table backup id to /home/db2inst

在/home/db2inst目录下的node0000目录下有一个data文件,是误删表的数据

通过DDL重建表,并使用LOAD将DATA文件导入表中即可.

没有做过备份的话,如果你拷贝的文件夹完整的话(既有元数据,又有数据库数据),可以uncatalog db dbname,然后将拷贝的文件夹拷贝回来,并catalog db dbname就可以了.

首先数据库要可以前滚恢复(数据库配置参数logretain或userexit打开)。

db2 connect to

dbname

db2 update db cfg using logretain on

db2 backup db dbname

(当打开归档日志后,该数据库会处于rollforward pending状态,所以要做一次全备份)

Linux, 环境, 数据库Linux, 数据库, 环境

通过如下备份脚本备份的数据库进行恢复

备份脚本:

. /home/db2admin/sqllib/db2profile   db2 backup db datedb online to /dbbackup/date include logs   cd /dbbackup/datetoday=`date +”%Y%m%d”`   file1=”*$today*”   ftpfile=`ls $file1`   echo $ftpfile   lftp -c “open ftp地址user 用户名密码@\$0put $ftpfile”   find /dbbackup/date -ctime +15 -exec rm {} \ 

恢复命令:

通过root命令登录到服务器上后切换到数据库用户名下用su – db2admin命令。

进入到备份文件存放目录即可。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/6719652.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-27
下一篇 2023-03-27

发表评论

登录后才能评论

评论列表(0条)

保存