ORA-02291: 违反完整约束条件 - 未找到父项关键字

ORA-02291: 违反完整约束条件 - 未找到父项关键字

2018.01.19 11:39:03字数 457阅读 3,177

最近,应该是很久了遇到这个问题,一直觉得不影响自己工作使用,就一直在执行sql的时候跳过了,但是,心里一直有个疙瘩。今天把问题解决了,很开心,就把解决问题的具体过程写一下,算是给自己一个记录。

有关此问题的所有文章中,都说了这个问题出现的场景:向某张表A中插入数据,A表的某个字段m是外键,关联到了另外一张表B,由此产生了问题。

解决方法无非三种:

首先要说的就是最不应该出现的问题:

数据类型长度不一致:即A表中的外键字段和B表中的被外键关联的字段数据类型长度不一致。由此产生了问题,这个问题如果出现,我觉得建表的人可以找个没人的地方面壁思过一下。

后面两种情况可以归为一类:

外键或者外键环中数据不一致:

外键:A表的外键关联的为B表中的字段,则应该A有数据则B必有数据,A为空则B必为空,如果A中有数据,但B中无数据,就会报错。

外键环:A表的外键关联的为B表中的字段,B表中的字段又为外键关联C表中的字段。。。。。。,这个过程中,出现外键数据不一致的问题,就会报错。

posted @ 2022-08-09 14:36  RedArmy  阅读(327)  评论(0编辑  收藏  举报