ORA-01779的处理方法(更新数据处理)
程序员文章站
2024-01-30 22:26:52
...
Oracle中试图对一个子查询进行更新时可能会出现ORA-01779错误。该错误的内容为: ORA-01779: cannot modify a column which maps
Oracle中试图对一个子查询进行更新时可能会出现ORA-01779错误。该错误的内容为:
ORA-01779: cannot modify a column which maps to a non-key-preserved table例如,使用以下的更新查询就会出现该错误。
这个错误的意思是,子查询的结果中,更新数据源(test2)的内容不唯一,导致被更新对象(test1)中的一行可能对应数据源(test2)中的多行。 本例中,,test2表的id不唯一,因此test2表中可能存在id相同但是num不相同的数据,这种数据是无法用来更新 test1 的。
解决方法就是保证数据源的唯一性,例如本例中可以为test2.id创建一个唯一索引:
CREATE UNIQUE INDEX test2_idx_001 ON test2 (id);
之后上面的更新就可以执行了。
另外也可以强制 Oracle 执行,方法是加上 BYPASS_UJVC 注释。
BYPASS_UJVC的作用是跳过Oracle的键检查。 这样虽然能够执行了,但是如果test2中存在不唯一的数据,test1就会被更新多次而导致意想不到的结果。
下一篇: 成为一个PHP专家:缺失的环节_PHP
推荐阅读
-
ORA-01779的处理方法(更新数据处理)
-
数据处理-Python批量修改文件夹下含多个文件夹中的所有图片名称
-
PHP程序处理网页表单的GET和POST方法另外用法
-
Node.js利用js-xlsx处理Excel文件的方法详解
-
shell中长命令的换行处理方法示例
-
Python使用 Beanstalkd 做异步任务处理的方法
-
PHP+Mysql基于事务处理实现转账功能的方法,mysql事务处理_PHP教程
-
cakephp setFlash()及flash()方法都不起作用,setFlash()的具体用法及简单案例,该如何处理
-
Audition CS6怎么使用? Audition处理音频的方法
-
JavaScript处理异步的几种方法