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 :关闭约束,删除索引,不能对表进行 插入/更新/删除等操作.

  • 相关阅读:
    Python 数据驱动 unittest + ddt
    接口知识介绍
    python 爬虫
    python 接口测试(三)
    基于PCA和SVM的人脸识别系统-error修改
    二分查找算法
    JAVA中运用数组的四种排序方法
    [Matlab] Attempt to execute SCRIPT *** as a function
    第36讲 activityForResult
    第35讲 Activity入门和跳转
  • 原文地址:https://www.cnblogs.com/zx3707/p/5706544.html
Copyright © 2011-2022 走看看