在用DB2导数据的时候,为了恢复自增主键,进行备份和恢复时,因为错误使用了nonrecoverable这个关键字,导致数据库表空间异常,说是备份时出现了问题。查了好多资料发现有个帖子不错,特整理做笔记。
一、问题出现: 在数据库做了一个load作业,末尾未加参数:nonrecoverable,结果导致目标表所在的表空间变为backup pending状态(0X0020)
二、解决方法:
1.切换到数据库实例用户登录数据库,查看表状态(数据库实例:cmsdb)
db2 connect to cmsdb
db2 list tablespaces show detail
只要状态不是0X0000都是非正常的数据
2.查看数据库参数
db2 get db cfg for cmsdb|grep USEREXIT
db2 get db cfg for cmsdb|grep LOGRETAIN
3.修改数据库参数
db2 update db cfg for cmsdbusing userexit on
db2 update db cfg for cmsdbusing logretain on
4.空备异常表空间(异常表空间名:CRM_DATA1)
db2 backup database cmsdb tablespace CRM_DATA1 online to /dev/null
这一步要等几分钟的样子,几分钟没有结束有点怕了,不要怕要再等一下
5.恢复数据库参数
db2 update db cfg for cmsdb using userexit off
db2 update db cfg for cmsdb using logretain off
6.验证
db2 list tablespaces show detail
注意:第 2-5步要用数据库管理员的身份登录db2inst1
原文来自
https://blog.csdn.net/dingguanyi/article/details/77902485