更新操作失败,SQLCODE=-803,如何排除故障?

Posted

技术标签:

【中文标题】更新操作失败,SQLCODE=-803,如何排除故障?【英文标题】:Update operation failed with SQLCODE=-803, how to troubleshoot? 【发布时间】:2019-02-08 19:45:30 【问题描述】:

我正在尝试根据某些条件更新表记录。当我更新少数最近的记录时,它可以正常工作,但是当我为更多的记录或更旧的记录运行它时,它会引发错误 查询:

update table_Name set Col1 = 'C' 
where date(TRN_SCH_DPT_DT)  < current date - 200 DAYS 

工作正常!

update table_Name set Col1 = 'C'
where date(TRN_SCH_DPT_DT)  < current date - 100 DAYS

抛出错误 => DB2 SQL 错误:

SQLCODE=-803,SQLSTATE=23505,SQLERRMC=2

注意:我没有更新主键。任何大于 200 的数字都可以正常工作。

【问题讨论】:

找出你正在打破的唯一约束,并修复它。对于这种情况,最好使用 MERGE。 旁注:您当前的查询可能会忽略您在TRN_SCH_DPT_DT 上可能拥有的任何索引。你最好把条件写成WHERE TRN_SCH_DPT_DT &lt; TIMESTAMP(CURRENT DATE - 100 DAYS) 【参考方案1】:

SQL0803N 的描述中有一条 SELECT 语句,它可以帮助您找到您的语句试图违反的唯一索引(IID=2)。

选择 INDNAME、INDSCHEMA 来自 SYSCAT.INDEXES 其中 IID = 2 AND TABSCHEMA = 'TABLE_SCHEMA' AND TABNAME = 'TABLE_NAME'

【讨论】:

您可能希望在答案中包含链接中的要点,以免链接过时。

以上是关于更新操作失败,SQLCODE=-803,如何排除故障?的主要内容,如果未能解决你的问题,请参考以下文章

常见DB2 sql错误码积累

db2插入数据失败

LISTAGG 失败,SQLCODE=-440

为啥我的查询因 SQLCODE = -420 而失败?

内置函数SQLCODE和SQLERRM的使用

Oracle内置函数SQLCODE和SQLERRM的使用