关于ORA-02273错误,以前还真没有仔细留意过。昨天遇到了这个问题,遂顺便总结一番,以后遇到这类问题就可以直接用下面方案解决。如下所示,我们首先准备一下测试环境。

CREATE TABLE TEST.TEST 

(  OWNER            VARCHAR2(30),

   OBJECT_ID        NUMBER,

   OBJECT_NAME      VARCHAR2(30) 

);

 

CREATE INDEX TEST.IX_TEST_N1 ON TEST.TEST(OBJECT_ID)  TABLESPACE TEST_DATA;

 

ALTER TABLE TEST.TEST ADD CONSTRAINT PK_TEST PRIMARY KEY (OBJECT_ID) USING INDEX TABLESPACE TEST_DATA;

 

CREATE TABLE TEST.RF_TEST

(

    ID           NUMBER,

    OBJECT_ID    NUMBER

);

 

ALTER TABLE TEST.RF_TEST ADD CONSTRAINT PK_RF_TEST  PRIMARY KEY(ID) USING INDEX TABLESPACE TEST_DATA;

 

ALTER TABLE TEST.RF_TEST ADD CONSTRAINT FK_RF_TEST FOREIGN KEY(OBJECT_ID ) REFERENCES TEST.TEST(OBJECT_ID);

如下所示,由于脚本上面的原因(没有指定主键约束对应的索引,而且又有其他索引在主键字段上,就会产生这种情况。暂时不清楚具体原因),导致TEST.TEST的主键约束对应的索引为IX_TEST_N1。

SELECT OWNER

      ,CONSTRAINT_NAME

      ,CONSTRAINT_TYPE

      ,TABLE_NAME

      ,INDEX_NAME

FROM DBA_CONSTRAINTS

WHERE TABLE_NAME='TEST';

此时假如我们要调整表TEST.TEST的主键,那么可以用下面脚本查看一下TEST表的主外键约束关系。如下所示:

SELECT DC.OWNER           AS "PARENT_TABLE_OWNER", 

       DC.TABLE_NAME      AS "PARENT_TABLE_NAME", 

       DC.CONSTRAINT_NAME AS "PRIMARY CONSTRAINT NAME", 

       DC.STATUS          AS "PRIMARY CONSTRAINT STATUS",

       DF.CONSTRAINT_NAME AS "REFERENCED CONSTRAINT NAME", 

       DF.STATUS          AS "FOREIGN CONSTRAINT STATUS",

       DF.STATUS          AS "CHILD_TABLE_OWNER", 

       DF.TABLE_NAME      AS "CHILD_TABLE_NAME" ,

       'ALTER TABLE ' || DF.OWNER  || '.' || DF.TABLE_NAME || ' DISABLE CONSTRAINT ' || DF.CONSTRAINT_NAME || ';'

FROM   DBA_CONSTRAINTS DC, 

       (SELECT C.OWNER, 

               C.CONSTRAINT_NAME, 

               C.R_CONSTRAINT_NAME, 

               C.TABLE_NAME,

               C.STATUS

        FROM   DBA_CONSTRAINTS C 

        WHERE  CONSTRAINT_TYPE = 'R') DF 

WHERE  DC.CONSTRAINT_NAME = DF.R_CONSTRAINT_NAME 

       AND DC.OWNER =UPPER('&OWNER')

       AND DC.TABLE_NAME=UPPER('&TABLE_NAME');

删除表的主键约束时,报如下错误:“ORA-02273: this unique/primary key is referenced by some foreign keys”

SQL> ALTER TABLE TEST.TEST DROP CONSTRAINT PK_TEST;

ALTER TABLE TEST.TEST DROP CONSTRAINT PK_TEST

                                      *

ERROR at line 1:

ORA-02273: this unique/primary key is referenced by some foreign keys

我们用最上面脚本生成的禁用外键约束的脚本,禁用外键约束后,然后删除表TEST.TEST的主键约束,依然报ORA-02273错误。

如上所示,不能通过先禁用外键约束,然后删除主键约束的这样操作,搜索了相关资料后,发现只能先删除外键约束,然后才能处理主键约束。

操作步骤如下:

1: 首先生成外键约束的创建脚本,后续删除外键约束后,需要重新创建外键约束。

ORACLE 11g或以上版本使用下面脚本:

--此脚本适用于Oracle 11g

SELECT  'ALTER TABLE ' || T1_OWNER || '.' || T1_TABLE_NAME

     || ' ADD CONSTRAINT ' || T1_CONSTRAINT_NAME

     || ' FOREIGN KEY (' || T1_COLUMN_NAMES || ')'

     || ' REFERENCES ' || T2_OWNER || '.' || T2_TABLE_NAME

     || '(' || T2_COLUMN_NAMES || ');' FK_SCRIPT

FROM

    (SELECT A.OWNER     T1_OWNER

          , A.TABLE_NAME T1_TABLE_NAME

          , A.CONSTRAINT_NAME T1_CONSTRAINT_NAME

          , B.R_CONSTRAINT_NAME T2_CONSTRAINT_NAME

          -- CONCATENATE COLUMNS TO HANDLE COMPOSITE

          -- FOREIGN KEYS

          , LISTAGG(A.COLUMN_NAME,', ') 

                  WITHIN GROUP (ORDER BY A.POSITION) 

                  AS T1_COLUMN_NAMES

    FROM DBA_CONS_COLUMNS A

       , DBA_CONSTRAINTS B

    WHERE A.CONSTRAINT_NAME = B.CONSTRAINT_NAME

    AND B.CONSTRAINT_TYPE = 'R'

    GROUP BY A.OWNER 

           , A.TABLE_NAME

           , A.CONSTRAINT_NAME

           , B.R_CONSTRAINT_NAME

    ) T1,

    (SELECT A.OWNER              T2_OWNER

          , A.TABLE_NAME       T2_TABLE_NAME

          , A.CONSTRAINT_NAME T2_CONSTRAINT_NAME

          -- CONCATENATE COLUMNS FOR PK/UK REFERENCED

          -- FROM A COMPOSITE FOREIGN KEY

          , LISTAGG(A.COLUMN_NAME,', ')

               WITHIN GROUP (ORDER BY A.POSITION)

               AS T2_COLUMN_NAMES

    FROM DBA_CONS_COLUMNS A

       , DBA_CONSTRAINTS B

    WHERE A.CONSTRAINT_NAME = B.CONSTRAINT_NAME

    AND B.CONSTRAINT_TYPE IN ( 'P', 'U' )

    GROUP BY A.OWNER

           , A.TABLE_NAME

           , A.CONSTRAINT_NAME ) T2

WHERE T1.T2_CONSTRAINT_NAME = T2.T2_CONSTRAINT_NAME

  AND T1.T1_OWNER  = T2.T2_OWNER

  AND T2.T2_OWNER ='&OWNER'

  AND T2.T2_TABLE_NAME = '&TABLE_NAME';

ORACLE 11g之前版本使用下面脚本

--此脚本适用于Oracle 10g

SELECT  'ALTER TABLE ' || T1_OWNER || '.' || T1_TABLE_NAME

   || ' ADD CONSTRAINT ' || T1_CONSTRAINT_NAME

   || ' FOREIGN KEY (' || T1_COLUMN_NAMES || ')'

   || ' REFERENCES ' || T2_OWNER || '.' || T2_TABLE_NAME

   || '(' || T2_COLUMN_NAMES || ');' FK_SCRIPT

FROM

  (SELECT A.OWNER   T1_OWNER

    , A.TABLE_NAME T1_TABLE_NAME

    , A.CONSTRAINT_NAME T1_CONSTRAINT_NAME

    , B.R_CONSTRAINT_NAME T2_CONSTRAINT_NAME

    -- CONCATENATE COLUMNS TO HANDLE COMPOSITE

    -- FOREIGN KEYS [HANDLES UP TO 5 COLUMNS]

    , MAX(DECODE(A.POSITION, 1,

         A.COLUMN_NAME,NULL)) ||

      MAX(DECODE(A.POSITION, 2,', '||

         A.COLUMN_NAME,NULL)) ||

      MAX(DECODE(A.POSITION, 3,', '||

         A.COLUMN_NAME,NULL)) ||

      MAX(DECODE(A.POSITION, 4,', '||

         A.COLUMN_NAME,NULL)) ||

      MAX(DECODE(A.POSITION, 5,', '||

         A.COLUMN_NAME,NULL))

        T1_COLUMN_NAMES

  FROM DBA_CONS_COLUMNS A

     , DBA_CONSTRAINTS B

  WHERE A.CONSTRAINT_NAME = B.CONSTRAINT_NAME

  AND B.CONSTRAINT_TYPE = 'R'

  GROUP BY A.OWNER

         , A.TABLE_NAME

         , A.CONSTRAINT_NAME

         , B.R_CONSTRAINT_NAME

  ) T1,

  (SELECT A.OWNER    T2_OWNER

    , A.CONSTRAINT_NAME T2_CONSTRAINT_NAME

    , A.TABLE_NAME T2_TABLE_NAME

    -- CONCATENATE COLUMNS FOR PK/UK REFERENCED

    -- FROM A COMPOSITE FOREIGN KEY

    , MAX(DECODE(A.POSITION, 1,

         A.COLUMN_NAME,NULL)) ||

      MAX(DECODE(A.POSITION, 2,', '||

         A.COLUMN_NAME,NULL)) ||

      MAX(DECODE(A.POSITION, 3,', '||

         A.COLUMN_NAME,NULL)) ||

      MAX(DECODE(A.POSITION, 4,', '||

         A.COLUMN_NAME,NULL)) ||

      MAX(DECODE(A.POSITION, 5,', '||

         A.COLUMN_NAME,NULL))

        T2_COLUMN_NAMES

  FROM DBA_CONS_COLUMNS A, DBA_CONSTRAINTS B

  WHERE A.CONSTRAINT_NAME = B.CONSTRAINT_NAME

  AND B.CONSTRAINT_TYPE IN ( 'P', 'U' )

  GROUP BY A.OWNER

         , A.TABLE_NAME

         , A.CONSTRAINT_NAME ) T2

WHERE T1.T1_OWNER = T2.T2_OWNER

  AND T1.T2_CONSTRAINT_NAME = T2.T2_CONSTRAINT_NAME

  AND T2.T2_OWNER ='&OWNER'

  AND T2.T2_TABLE_NAME = '&TABLE_NAME';

使用上面脚本生成的脚本为

ALTER TABLE TEST.RF_TEST ADD CONSTRAINT FK_RF_TEST FOREIGN KEY (OBJECT_ID) REFERENCES TEST.TEST(OBJECT_ID);

2:生成删除外键约束的脚本

SELECT 'ALTER TABLE ' 

       || OWNER || '.' || TABLE_NAME

       || ' DROP CONSTRAINT '

       || CONSTRAINT_NAME

       ||';' CONSTRAINT_DISABLE

FROM  DBA_CONSTRAINTS

WHERE CONSTRAINT_TYPE = 'R'

AND STATUS = 'ENABLED'

AND R_CONSTRAINT_NAME IN

 (

   SELECT CONSTRAINT_NAME 

   FROM DBA_CONSTRAINTS

   WHERE CONSTRAINT_TYPE IN ('P', 'U')

    AND OWNER='&OWNER'

    AND TABLE_NAME = '&TABLE_NAME'

 ); 

执行上面脚本生成的脚本,删除外键约束。

SQL> ALTER TABLE TEST.RF_TEST DROP CONSTRAINT FK_RF_TEST;

 

Table altered.

3:删除表TEST.TEST的主键

SQL> ALTER TABLE TEST.TEST DROP CONSTRAINT PK_TEST;

 

Table altered.

 

SQL> SELECT OWNER 

  2        ,TABLE_NAME

  3        ,INDEX_NAME

  4  FROM DBA_INDEXES 

  5  WHERE  TABLE_NAME='TEST';

 

OWNER      TABLE_NAME                     INDEX_NAME

---------- ------------------------------ ------------------------------

TEST        TEST                           IX_TEST_N1

 

SQL> 

如下所示,这种情况下,删掉了约束,并不会删除对应的索引。所以必须手工删除该索引

4: 在表TEST.TEST上增加主键约束, 在表TEST.RF_TEST上添加外键约束。

SQL> ALTER TABLE TEST.TEST ADD CONSTRAINT PK_TEST PRIMARY KEY(OBJECT_ID) USING INDEX TABLESPACE TEST_DATA;

 

 

 

Table altered.

 

 

 

SQL> ALTER TABLE TEST.RF_TEST ADD CONSTRAINT FK_RF_TEST FOREIGN KEY (OBJECT_ID) REFERENCES TEST.TEST(OBJECT_ID);

 

 

 

Table altered.

 

 

 

SQL> 

ORA-02273: this unique/primary key is referenced by some foreign keys的更多相关文章

  1. ORA-02266: unique/primary keys in table referenced by enabled foreign keys

    在数据库里面使用TRUNCATE命令截断一个表的数据时,遇到如下错误 SQL >TRUNCATE TABLE ESCMOWNER.SUBX_ITEM ORA-02266: unique/prim ...

  2. ORA-02429: cannot drop index used for enforcement of unique /primary key

    相信不少人遇到过ORA-02429: cannot drop index used for enforcement of unique /primary key 这个错误,对应的中文提示"O ...

  3. Each record in table should have a unique `key` prop,or set `rowKey` to an unique primary key.

    Each record in table should have a unique `key` prop,or set `rowKey` to an unique primary key. 1.rea ...

  4. oracle约束总结(not null/unique/primary key/foreign key/check)

    约束(constraint):对创建的表的列属性.字段进行的限制. 诸如:not null/unique/primary key/foreign key/check 作用范围:         ①列级 ...

  5. antd desgin vue 报错 Warning: Each record in table should have a unique `key` prop,or set `rowKey` to an unique primary key.

    警告:表的数据源中的每条记录都应该有一个唯一的“key”道具,或者将表的“rowKey”设置为一个唯一的主键, 只需要添加 :rowKey="record => record.id&q ...

  6. React表格报错Each record in table should have a unique `key` prop,or set `rowKey` to an unique primary key.

    解决: <Table bordered rowKey={record=>record.id} //解决 components={this.components} columns={colu ...

  7. mysql中key 、primary key 、unique key 与index区别

    一.key与primary key区别 CREATE TABLE wh_logrecord ( logrecord_id ) NOT NULL auto_increment, ) default NU ...

  8. 数据库六大约束用法:主键(primary key)、外键(foreign key)、非空(not null)、默认(default)、检查(check)、唯一(unique)

    1. 数据库有六大约束 主键(primary key) 外键(foreign key):被参照的键必须有唯一约束或是主键 非空(not null) 默认(default) 检查(check):orac ...

  9. MySQL中KEY、PRIMARY KEY、UNIQUE KEY、INDEX 的区别

    参考:MySQL中KEY.PRIMARY KEY.UNIQUE KEY.INDEX 的区别 对于题目中提出的问题,可以拆分来一步步解决.在 MySQL 中 KEY 和 INDEX 是同义.那这个问题就 ...

随机推荐

  1. 三台主机搭建LAMP(apache、mariadb、php)

    实验环境:均是CentOS7 httpd:172.16.254.88   2.4.6 PHP:172.16.250.140 5.4.16 mariadb:172.16.250.94 5.5.52 第三 ...

  2. [UE4]C++设置AnimInstance的相关问题

    注意:ue4 4.17调用LoadObject<UAnimBlueprintGeneratedClass>直接崩 http://aigo.iteye.com/blog/2285001 UA ...

  3. Unity5.5 Lighting Scene

    参考:https://docs.unity3d.com/Manual/GlobalIllumination.html Environment Lighting(环境光) Skybox: 天空盒材质,这 ...

  4. Solr 6.7学习笔记(07)-- More Like This

    Solr中提供了MoreLikeThis的功能,用于查询相似的文档 .应用场景(个人理解):1. 你写的文章和别人文章相似度高的话,有一方是抄袭的可能性就很大.2. 查找相似的产品. MoreLike ...

  5. poj3186(区间dp)

    题目链接:http://poj.org/problem?id=3186 题意:给一行n个数,每次可以取出行首或者行末的数,如果第ai是第i次取出的,可以得到ai*i的收益,求最大的总收益: 思路:区间 ...

  6. codeforces358D Dima and Hares【dp】

    从本质入手,这个东西影响取值的就是相邻两个哪个先取 设f[i][0/1]为前i个(i-1,i)中先取i/i-1的值(这里不算上i的贡献 转移就显然了,注意要先复制-inf #include<io ...

  7. 洛谷P1044 栈(Catalan数)

    P1044 栈 题目背景 栈是计算机中经典的数据结构,简单的说,栈就是限制在一端进行插入删除操作的线性表. 栈有两种最重要的操作,即pop(从栈顶弹出一个元素)和push(将一个元素进栈). 栈的重要 ...

  8. Spring Boot Dubbo 构建分布式服务

    概述: 节点角色说明 节点 角色说明 Provider 暴露服务的服务提供方 Consumer 调用远程服务的服务消费方 Registry 服务注册与发现的注册中心 Monitor 统计服务的调用次数 ...

  9. 求n位水仙花数

    求n位水仙花数 A.两个关键 1.n位水仙花数的范围是什么? n位水仙花数的范围是[10n-1,10n) 2.如何判断是否为水仙花数 核心操作: 2-1.如何得到每一位? A.核心思想 对得到的数进行 ...

  10. Domination

    题目链接 #include <bits/stdc++.h> using namespace std; typedef long long ll; inline ll read(){ , f ...