您的位置:首页 > 数据库

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

2016-04-15 15:13 1191 查看
对表进行任何操作都不被允许,提示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; 

=====================================================================================================

db2删除表字段后,需要重组,一般我都用:call Sysproc.admin_cmd('REORG TABLE 表名');

表处于暂挂状态也可以用这句恢复。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  db2 sql