DB2中SQLSTATE=57016 SQLCODE=-668,原因码 "7"的解决方法

对表进行任何操作都不被允许,提示SQLSTATE=57016 SQLCODE=-668 ,原因码 "7"的错误:SQL0668N  Operation not allowed for reason code "7" on table XXX. 解决方法为:执行命令:reorg table XXX;即可。
参考原文为:
Operation not allowed for reason code reason-code on table table-name.
Explanation: Access to table table-name is restricted. The cause is based on the following reason codes reason-code: 7
    The table is in the reorg pending state. This can occur after an ALTER TABLE statement containing a REORG-recommended operation.7
    Reorganize the table using the REORG TABLE command (note that INPLACE REORG TABLE is not allowed for a table that is in the reorg pending state).
其中:
   reorg   table   <tablename>   通过重构行来消除“碎片”数据并压缩信息,对表进行重组。
   runstats   on   table   <tbschema>.<tbname>   收集表   <tbname>   的统计信息。
   reorgchk   on   table   all   确定是否需要对表进行重组,对于对所有表自动执行   runstats   很有用。
  >>> reorg   和runstats   都是单个表优化,初始化的命令: 
           runstats on table administrator.test;

           reorg table administrator.test;


出处:http://www.blogjava.net/zqbchina/articles/134702.html


补充:

1、通过db2 get snapshot for locks on db_name,获取了数据库上所有锁的信息,查到目标表并不是因为应用程序连接,导致的死锁,所以不能通过db2 force application (应用程序ID),来释放锁。


2、目标表是数据库内部锁定,锁定方式是IX锁(意向互斥锁),对表级锁的解锁方式,就是通过重组表实现。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值