zoukankan      html  css  js  c++  java
  • 设置主外键时 ORA-02298: 无法验证

    主要原因是:

     

    在添加CONSTRAINT的时候,默认是需要VALIDATE表中的已有数据的。

    你要插入的表A里,有外键连接到另一个表B的主键,你在表A的外键列插入的值,在表B的主键列找不到就不能插入。主要看两表中的数据是否一致,从表中要关联外键的字段中的数据必须包含在主表相关字段的数据内。

     

    处理的方法有:

    1> 先不验证已有数据的CONSTRANT,加上参数NOVALIDATE.

    ALTER TABLE sub_tab ADD CONSTRAINT fk_sub_tab foreign KEY (main_id) references main_tab(id) NOVALIDATE;

    alter table table_name-----------------------意思就是要改动某个表

    add constraint constraint_name-------------意思就是给某个表加约束/限制

    foreign key(column_name)------------------说明是外键的约束,而且是某个column的。

    references table_name(id);------------------指定这个外键是属于哪个表的

    启用约束:
    enable( validate) :启用约束,创建索引,对已有及新加入的数据执行约束.
    enable novalidate :启用约束,创建索引,仅对新加入的数据强制执行约束,而不管表中的现有数据. 

    禁用约束:
    disable( novalidate):关闭约束,删除索引,可以对约束列的数据进行修改等操作.
    disable validate :关闭约束,删除索引,不能对表进行 插入/更新/删除等操作.

  • 相关阅读:
    SAX解析XML笔记
    使用 Angular 2 来创建FlexGrid控件
    算法-快速排序(优雅版)
    使用泛型简化动态代理
    Java泛型概述
    POI-PPT官方文档
    Java 利用POI操作PPT
    Java8学习笔记(九)--日期/时间(Date Time)API指南
    Java8学习笔记(八)--方法引入的补充
    Android WebView加载本地html并实现Java与JS交互
  • 原文地址:https://www.cnblogs.com/zx3707/p/5706544.html
Copyright © 2011-2022 走看看