oracle中的违反完整性约束条件问题

在用sql语句创建表时,出现了下列问题:
在这里插入图片描述
在这,把这个问题出现的原因总结一下:

1.数据类型长度不一致

A表中的外键字段和B表中的被外键关联的字段数据类型或长度不一致。由此产生了问题,这个问题是最难发现,也最不该出现的错误;

2.外键数据不一致

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

3.外键环中数据不一致

A表的外键关联的为B表中的字段,B表中的字段又为外键关联C表中的字段。产生了外键环,就是B表中被外键关联的字段又关联了C表中的字段,而C中相应字段却没有数据,出现外键数据不一致的问题,则产生这种情况。

PS:
关于约束的常用知识点:
(1)主键约束和唯一键约束均会隐式创建同名的唯一索引,当主键约束或者唯一键约束失效时,隐式创建的唯一索引会被删除;

(2)主键约束要求列值非空,而唯一键约束和唯一索引不要求列值非空;

(3)相同字段序列不允许重复创建索引;

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值