温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

oracle中如何批量删除表数据

发布时间:2020-10-26 15:40:57 来源:亿速云 阅读:516 作者:Leah 栏目:开发技术

这期内容当中小编将会给大家带来有关oracle中如何批量删除表数据,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

1.情景展示

  情景一:

  删除PRIMARY_INDEX_TEST表中,MINDEX_ID字段为空的数据

oracle中如何批量删除表数据

  情景二:

  删除VIRTUAL_CARD_TEST表中的脏数据

oracle中如何批量删除表数据

2.解决方案

  情景一的解决方案: 

DELETE FROM PRIMARY_INDEX_TEST WHERE MINDEX_ID IS NULL

oracle中如何批量删除表数据

  情景二的解决方案:

  方案1:使用快速游标法(删除一次提交一次);

--快速游标法
BEGIN
 FOR TEMP_CURSOR IN (SELECT ID
            FROM VIRTUAL_CARD3
            WHERE INSTR(NAME, '*') > 0
           UNION
           SELECT ID
            FROM VIRTUAL_CARD3
            WHERE INSTR(NAME, '#') > 0
           UNION
           SELECT ID
            FROM VIRTUAL_CARD3
            WHERE INSTR(NAME, '/') > 0
           UNION
           SELECT ID
            FROM VIRTUAL_CARD3
            WHERE INSTR(NAME, '+') > 0
           UNION
           SELECT ID
            FROM VIRTUAL_CARD3
            WHERE INSTR(NAME, '!') > 0
           UNION
           SELECT ID
            FROM VIRTUAL_CARD3
            WHERE INSTR(NAME, '.') > 0) LOOP
  /* LOOP循环的是TEMP_CURSOR(逐条读取TEMP_CURSOR) */
  DELETE FROM VIRTUAL_CARD3 WHERE VIRTUAL_CARD3.ID = TEMP_CURSOR.ID;
  COMMIT; --提交
 END LOOP;
END;

  执行时间:

oracle中如何批量删除表数据

  方案2:更多游标使用方法,见文末推荐;

  方案3:使用存储过程按id进行逐条删除。

CREATE OR REPLACE PROCEDURE DELETE_TABLE_BATCH(V_ROWS IN NUMBER /*删除多少条数据后进行提交*/) IS
 /**
 * 内容:
 * 日期:2018/12/05
 * 作者:Marydon
 * 版本:1.0
 */
 I NUMBER(10); --声明变量,用于记录次数
BEGIN
 FOR TEMP_TABLE IN (SELECT ID
            FROM VIRTUAL_CARD_TEST
           WHERE INSTR(NAME, '*') > 0
           UNION
           SELECT ID
            FROM VIRTUAL_CARD_TEST
           WHERE INSTR(NAME, '#') > 0
           UNION
           SELECT ID
            FROM VIRTUAL_CARD_TEST
           WHERE INSTR(NAME, '/') > 0
           UNION
           SELECT ID
            FROM VIRTUAL_CARD_TEST
           WHERE INSTR(NAME, '+') > 0
           UNION
           SELECT ID
            FROM VIRTUAL_CARD_TEST
           WHERE INSTR(NAME, '!') > 0
           UNION
           SELECT ID
            FROM VIRTUAL_CARD_TEST
           WHERE INSTR(NAME, '.') > 0) LOOP
  /* LOOP循环的是TEMP_TABLE(逐条读取TEMP_TABLE) */
  DELETE VIRTUAL_CARD_TEST WHERE VIRTUAL_CARD_TEST.ID = TEMP_TABLE.ID;
  I := I + 1; --删除一次,+1
  IF I >= V_ROWS THEN
   COMMIT; --提交
   I := 0; --重置
  END IF;
 END LOOP;
EXCEPTION
 /* 输出异常信息 */
 WHEN OTHERS THEN
  DBMS_OUTPUT.PUT_LINE('异常编号:' || SQLCODE);
  DBMS_OUTPUT.PUT_LINE('异常信息:' || SQLERRM);
  ROLLBACK; --回滚
END DELETE_TABLE_BATCH;

  创建并运行该存储过程

oracle中如何批量删除表数据

  删除16522条数据,用了6分21秒,比方式一慢太多了。 

  方案4:

  将要保留的数据插入到新表

--将要保留的数据插入到新表
CREATE TABLE VIRTUAL_CARD_TEMP2 AS(
SELECT *
 FROM VIRTUAL_CARD2
 WHERE INSTR(NAME, '*') = 0
  AND INSTR(NAME, '#') = 0
  AND INSTR(NAME, '/') = 0
  AND INSTR(NAME, '+') = 0
  AND INSTR(NAME, '!') = 0
  AND INSTR(NAME, '.') = 0)

  删除原来的表

--删除原表
drop table VIRTUAL_CARD2

  将新建的表进行重命名成删除表的名称。

  说明:原来的表有过存在外键约束等关系时,并没有进行测试,因为该表没有索引之类东西,自己测试的时候一定要慎重!!!

  方案5:使用in函数

DELETE FROM VIRTUAL_CARD_TEMP
 WHERE ID_CARD IN (SELECT T1.ID_CARD
                     FROM VIRTUAL_CARD_TEMP T1
                    WHERE INSTR(T1.NAME, '*') > 0
                   UNION
                   SELECT T1.ID_CARD
                     FROM VIRTUAL_CARD_TEMP T1
                    WHERE INSTR(T1.NAME, '#') > 0
                   UNION
                   SELECT T1.ID_CARD
                     FROM VIRTUAL_CARD_TEMP T1
                    WHERE INSTR(T1.NAME, '/') > 0
                   UNION
                   SELECT T1.ID_CARD
                     FROM VIRTUAL_CARD_TEMP T1
                    WHERE INSTR(T1.NAME, '+') > 0
                   UNION
                   SELECT T1.ID_CARD
                     FROM VIRTUAL_CARD_TEMP T1
                    WHERE INSTR(T1.NAME, '!') > 0
                   UNION
                   SELECT T1.ID_CARD
                     FROM VIRTUAL_CARD_TEMP T1
                    WHERE INSTR(T1.NAME, '.') > 0)

  说明:ID_CARD字段必须具有唯一性。 

oracle中如何批量删除表数据

上述就是小编为大家分享的oracle中如何批量删除表数据了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI