db2报错Operationnotallowedforreason
1.表操作错误SQL0668N Operation not allowed for reason code "1" on table "XXXX". SQLSTATE=57016的解决⽅法
The table is in Check Pending state. The integrity of the table is not enforced and the content of the table may be invalid.
An operation on a parent table or an underlying table that is not in a check pending state may also receive this error if a dependent table is in a check pending state.
Execute the SET INTEGRITY statement with the IMMEDIATE CHECKED option on table table-name to bring the table out of the Check Pending state.
www.2cto
For a user maintained materialized query table, execute the statement with the IMMEDIATE UNCHECKED option instead of the IMMEDIATE CHECKED option.:
ERROR [57016] [IBM][DB2/AIX64] SQL0668N  Operation not allowed for reason code "1" on table "XXXX".  SQLSTATE=57016
可能有⼀⾏或多⾏违反了对数据定义的约
束。此表不能⽤于操作。若从属表处于检查暂挂状态,则对不处于检查暂挂
状态的⽗表的操作也可能接收到此错误。
⽤户响应: 执⾏带有 IMMEDIATE CHECKED 选项的 SET INTEGRITY
语句,并确保数据符合对该表或从属于它的表定义的所有约束。
set integrity for 表名immediate checked
2.对表进⾏任何操作都不被允许,提⽰SQLSTATE=57016 SQLCODE=-668 ,原因码 "7"的错误:SQL0668N Operation not allowed for reason code "7" on table XXX. 解决⽅法为:
pending
执⾏命令:
[html]
1. 执⾏ CALL SYSPROC.ADMIN_CMD('reorg table XXXXXXX')
2. XXXXXXX'为表名
参考原⽂为:
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 st;
reorg st;
3.Operation not allowed for reason code "3" on table xxx
问题:
select count(*) from schema_name.table_name with ur;
: ERROR [57016] [IBM]
[DB2/LINUXX8664] SQL0668N  Operation not allowed for reason code "3" on table "schema_name.table_name".  SQLSTATE=57016
我刚才
Reorg table schema_name.table_name;
DB2 Database Error: ERROR [01H52] [IBM][DB2/LINUXX8664] SQL2216N  SQL error "-
668" occurred while reorganizing a database table or its indexes.  SQLSTATE=01H52
1.重组表的时候不能进⾏任何操作
2.可以删除表重建
3.使⽤ load 命令,重启或者断开load pending状态,place或start解除暂挂状态

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。