从表 oracle 中删除所有约束

Remove all constraints from a table oracle(从表 oracle 中删除所有约束)
本文介绍了从表 oracle 中删除所有约束的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

伙计们,我的问题是我不知道我添加到表中的约束名称.但我需要删除或禁用所有这些外键约束.但是怎么做呢?

SQL> desc orders;


Name                                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 ORDER_ID                                  NOT NULL VARCHAR2(10)
 PRODUCT_ID                                         VARCHAR2(10)
 DATE_OF_ORDER                                      TIMESTAMP(6)
 CUST_ID                                            VARCHAR2(10)
 QUANTITY                                           NUMBER(38)
 TOTAL_PRICE                                        FLOAT(10)
 DELIVERY_STATUS                                    VARCHAR2(10)

推荐答案

相关的外约束可以通过user_constraints字典视图来确定,可以通过下面的代码块

The related foreign constraints might be determined by using user_constraints dictionary view, and you can disable the foreign key constraint of this table by the following code block

BEGIN
  FOR c IN
    (
      SELECT * 
        FROM user_constraints c
       WHERE c.constraint_type = 'R'
         AND c.table_name = 'ORDERS')
  LOOP
    EXECUTE IMMEDIATE 'ALTER TABLE '||c.table_name||
                      ' DISABLE CONSTRAINT '||c.constraint_name;
  END LOOP;
END;  
/

这篇关于从表 oracle 中删除所有约束的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

SQL to Generate Periodic Snapshots from Transactions Table(用于从事务表生成定期快照的SQL)
MyBatis support for multiple databases(MyBatis支持多个数据库)
Oracle 12c SQL: Missing column Headers in result(Oracle 12c SQL:结果中缺少列标题)
SQL query to find the number of customers who shopped for 3 consecutive days in month of January 2020(查询2020年1月连续购物3天的客户数量)
How to get top 10 data weekly (This week, Previous week, Last month, 2 months ago, 3 month ago)(如何每周获取前十大数据(本周、前一周、上个月、2个月前、3个月前))
Select the latest record for an Id per day - Oracle pl sql(选择每天ID的最新记录-Oracle pl SQL)