ORA-02291: 违反完整约束条件 - 未找到父项关键字
2015-11-15 20:54
393 查看
总体说说可能出现的原因:
情况场景:
表A中有个字段是外键,关联了表B中的某字段,再往表A插入数据时,会出现这种情况。
可能原因:
1.
eg.创建A表
![](http://hi.csdn.net/attachment/201201/16/0_1326726909Fvfz.gif)
创建B表
![](http://hi.csdn.net/attachment/201201/16/0_1326727068D813.gif)
向A表插入数据
![](http://hi.csdn.net/attachment/201201/16/0_1326727946Kq9x.gif)
向B表插入数据
![](http://hi.csdn.net/attachment/201201/16/0_1326727994jyeQ.gif)
向B 表中插入数据,B表中某个字段(外键)在A表(主表)中没有值:2没在主表中
![](http://hi.csdn.net/attachment/201201/16/0_1326728223nxMx.gif)
向B 表中插入数据,B表中某个字段(外键),值为空的情况;
![](http://hi.csdn.net/attachment/201201/16/0_1326728628bTRR.gif)
2.产生了外键环,就是B表中被外键关联的字段又关联了C表中的字段,而C中相应字段却没有数据,则产生这种情况。
3.如果不是上两种情况,那么就是一个非常容易疏忽的问题:A中的外键字段和B中的被外键关联字段数据类型和长度不一致。特别是数据长度,必须要一致。
第三种情况是最容易忽略的,希望大家注意。
情况场景:
表A中有个字段是外键,关联了表B中的某字段,再往表A插入数据时,会出现这种情况。
可能原因:
1.
插入的数据<strong>如果某个字段是外键 那么该值要么为空 要么在主键表中 有对应的主键值</strong>否则 就不满足参照完整性约束 所以你肯定插入了 不存在的主键值 所以产生了这个错误
![](http://hi.csdn.net/attachment/201201/16/0_1326726909Fvfz.gif)
创建B表
![](http://hi.csdn.net/attachment/201201/16/0_1326727068D813.gif)
向A表插入数据
![](http://hi.csdn.net/attachment/201201/16/0_1326727946Kq9x.gif)
向B表插入数据
![](http://hi.csdn.net/attachment/201201/16/0_1326727994jyeQ.gif)
向B 表中插入数据,B表中某个字段(外键)在A表(主表)中没有值:2没在主表中
![](http://hi.csdn.net/attachment/201201/16/0_1326728223nxMx.gif)
向B 表中插入数据,B表中某个字段(外键),值为空的情况;
![](http://hi.csdn.net/attachment/201201/16/0_1326728628bTRR.gif)
2.产生了外键环,就是B表中被外键关联的字段又关联了C表中的字段,而C中相应字段却没有数据,则产生这种情况。
3.如果不是上两种情况,那么就是一个非常容易疏忽的问题:A中的外键字段和B中的被外键关联字段数据类型和长度不一致。特别是数据长度,必须要一致。
第三种情况是最容易忽略的,希望大家注意。
相关文章推荐
- 人生的改变———人生的开端
- 【树链剖分】[SPOJ-QTREE]Query on a tree
- 递归的性能分析与经典运用
- MySql服务启动不了的问题
- 原生JS 获取浏览器、窗口、元素等尺寸的方法及注意事项
- Java [leetcode 36]Valid Sudoku
- .NET破解之分享给新注册的朋友
- Redhat源码编译*.tar.gz安装包(一)
- AutoLayout总结
- js学习笔记
- 【Java】Java运行cmd命令直接导出.sql文件
- 【uml】-总结
- Sublime Text3插件安装
- HDU4842-过河
- 我的MYSQL学习心得链接
- 安装inotify-tools,用inotifywait命令监听文件或目录的访问信息
- Android经典例子收藏笔记1
- Android ListView setSelection()方法的介绍
- soj 2307 String Matching(KMP)
- poj1797