ORA-38914: Either mutate the error or ignore row on unique violation
Cause: IGNORE_ROW_ON_DUPKEY_INDEX and CHANGE_DUPKEY_ERROR_INDEX were both specified in the same statement.
Action: You cannot specify both hints in the same statement. Remove one of these two hints, or both, from the statement.
ORA-38914是一个Oracle数据库运行时的错误,它表示插入的行与数据库中的某一行重复,违反了包括唯一约束或主键在内的约束。
该错误的官方解释是:“ORA-38914:无法完成 INSERT 操作,必须更改错误以符合约束条件,或者忽略该行发生的唯一约束违规。”
常见案例是在插入数据时,数据库存在类似但不完全相同的行,希望在数据库中插入一个除了主键列以外完全相同的行。
1. 检查插入表中的其他行,以确认是哪个列发生了重复。
2. 使用主键约束或唯一约束的修改语句对插入行进行突变,以使其能够满足约束。
3. 如果不希望或不需要突变行,可以使用 IGNORE_ROW_ON_DUPKEY=TRUE 覆盖约束条件,抑制 ORA-38914 错误,并继续执行插入操作。