DB2表暫掛的原因及解決辦法
在使用DB2數(shù)據(jù)庫時,查詢一個表的數(shù)據(jù),SQL為:select * from db2admin.AlarmTarget,此時報錯,錯誤號為:SQL0668N SQL0668N 不允許對表 "<表名>" 執(zhí)行操作,限制對表 "<表名>" 的訪問。本文將為您分析表暫掛的原因及解決辦法。
原因基于下列:
1 該表處于“設置完整性暫掛無訪問”狀態(tài)。未強制表的完整性并且表的內容可能是無效的。如果從基礎表執(zhí)行的操作也可能會接收到此錯誤。
2 表處于“無數(shù)據(jù)移動”狀態(tài)。當處于此狀態(tài)時,禁止導致數(shù)據(jù)移動的操作。數(shù)據(jù)移動操作包括REDISTRIBUTE、數(shù)據(jù)庫分區(qū)鍵的更新、多維集群鍵的更新、范圍集群鍵的更新、數(shù)據(jù)分區(qū)鍵的更新和 REORG TABLE。
3 表處于“裝入暫掛”狀態(tài)。對此表的先前的 LOAD嘗試失敗。在重新啟動或終止 LOAD操作之前不允許對表進行訪問。
4 表處于“讀訪問”狀態(tài)。此狀態(tài)可以在聯(lián)機裝入(LOAD)處理(帶有 READ ACCESS 選項的 LOAD INSERT)期間發(fā)生,或在聯(lián)機裝入(LOAD)操作后發(fā)生,除了在使用SET INTEGRITY
5 表處于“正在裝入”狀態(tài)。LOAD 實用程序當前對此表進行操作,直到 LOAD完成才允許訪問。
6 不能在 ESE 中刷新引用昵稱的具體化查詢表。
7 表處于“REORG 暫掛”狀態(tài)。在執(zhí)行包含 REORG 建議的操作的 ALTER TABLE語句后,可能會發(fā)生這種情況。
8 表處于“改變暫掛”狀態(tài)。當在包含 REORG 建議的操作的 ALTER TABLE語句所在工作單元中使用該表時,就可能會發(fā)生這種情況。#p#
解決方法
1 對表 "<表名>" 執(zhí)行帶有 IMMEDIATE CHECKED 選項的SETINTEGRITY 語句,以使表脫離“設置完整性暫掛無訪問” 狀態(tài)。對于用戶維護的具體化查詢表,執(zhí)行帶有IMMEDIATE UNCHECKED選項的語句,而不是帶 IMMEDIATECHECKED選項。
2 對表 "<表名>"的從屬立即具體化查詢表和登臺表執(zhí)行 REFRESH TABLE語句??梢酝ㄟ^先前的 LOAD INSERT 操作根據(jù)"<表名>" 的追加數(shù)據(jù)以及通過先前帶有 ATTACH子句的 ALTER TABLE 語句根據(jù) "<表名>"
3 通過分別發(fā)出帶有 RESTART 或 TERMINATER 選項的LOAD來重新啟動或終止先前失敗的對此表的 LOAD 操作。
4 發(fā)出 LOAD QUERY
命令以檢查該表是否正在裝入。如果是,則一直等到 LOAD 實用程序完成,或如有必要,重新啟動或終止先前失敗的“裝入”操作。如果當前未在進行LOAD,則發(fā)出帶有 IMMEDIATE CHECKED 選項的 SET INTEGRITY語句以驗證表的新裝入部分中的約束。
5 一直等到當前 LOAD 操作完成。可用使用 LOAD QUERY命令來監(jiān)視裝入的進度。
6 使用 MAINTAIN BY USER
選項定義具體化查詢表。然后,使用帶有子查詢的INSERT 語句填充具體化查詢表。
7 使用 REORG TABLE命令重組表(注意,不允許對處于“REORG暫掛”狀態(tài)的表執(zhí)行 INPLACE REORG TABLE)。
8 完成該工作單元,然后重新發(fā)出該命令。
sqlcode : -668
sqlstate : 57007 解決方案:
在服務器端CLP執(zhí)行下列命令即可:
SET INTEGRITY FOR DB2ADMIN.ALARMTARGET IMMEDIATE CHECKED
說明:如果表處于"設置完整性暫掛"的狀態(tài),那么就需要盡快處理,否則該表不能進行 Select、Update、Delete 等操作。