Oracle删除表主键语句

本文介绍了一种在Oracle数据库中自动删除表的主键约束的方法。通过创建一个PL/SQL函数,该函数可以根据指定的表名和字段名查找并删除相应的主键约束。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

删除无名主键语句:

SELECT * FROM USER_CONS_COLUMNS WHERE TABLE_NAME = '表名';
ALTER TABLE 表名 DROP CONSTRAINT 主键名称;

上面语句需要手动,如何自动执行?看下面:

CREATE OR REPLACE FUNCTION DEL_TABLE_CONSTRAINT (tb_name       VARCHAR2,
                                                 field_name    VARCHAR2)
   RETURN NUMBER
IS
   con_count   NUMBER;
   con_name    VARCHAR2 (32);
BEGIN
   con_name := '';
   con_count := 0;

   SELECT COUNT (DISTINCT constraint_name)
     INTO con_count
     FROM user_cons_columns
    WHERE     table_name = UPPER (tb_name)
          AND column_name = UPPER (field_name)
          AND ROWNUM = 1;

   IF con_count > 0
   THEN
      SELECT DISTINCT constraint_name
        INTO con_name
        FROM user_cons_columns
       WHERE     table_name = UPPER (tb_name)
             AND column_name = UPPER (field_name)
             AND ROWNUM = 1;

      EXECUTE IMMEDIATE
         'alter table ' || tb_name || ' drop constraint ' || con_name;
   END IF;

   RETURN 0;
END;

这样执行

DECLARE
   a   NUMBER;
BEGIN
   a := DEL_TABLE_CONSTRAINT ('表名', '字段名');
END;
/

 

转载于:https://www.cnblogs.com/mygod/p/5790172.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值