怎么提高dml的性能
这篇文章主要介绍“怎么提高dml的性能”,在日常操作中,相信很多人在怎么提高dml的性能问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么提高dml的性能”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
若是批量处理海量数据的话通常都是很复杂及缓慢的,方法也很多,但是通常的概念是:分批删除,逐次提交。下面介绍一下提高DML语句效率的常用方法。
UPDATE
① 多字段更新使用一个查询。
② 将表修改为NOLOGGING模式。
③ 根据情况决定是否暂停索引,更新后恢复。避免在更新的过程中涉及到索引的维护。
④ 批量更新,每更新一些记录后及时进行提交动作,避免大量占用回滚段和临时表空间。
⑤ 可以创建一个临时的大的表空间用来应对这些更新动作。
⑥ 加大排序缓冲区。
⑦ 如果更新的数据量接近整个表,那么就不应该使用索引而应该采用全表扫描。
⑧ 如果服务器有多个CPU,那么可以采用PARELLEL Hint,可以大幅度地提高效率。
⑨ 建表的参数非常重要,对于更新非常频繁的表,建议加大PCTFREE的值,以保证数据块中有足够的空间用于UPDATE。
⑩ 通过快速游标更新法,并对ROWID进行排序更新,如下所示:
DECLARE
V_COUNTER NUMBER;
BEGIN
V_COUNTER := 0;
FOR CUR IN (SELECT A.AREA_CODE, B.ROWID ROW_ID FROM TA A, TB B WHERE A.ID = B.ID ORDER BY B.ROWID ) LOOP
UPDATE TB SET AREA_CODE = CUR.AREA_CODE WHERE ROWID = CUR.ROW_ID;
V_COUNTER := V_COUNTER + 1;
IF (V_COUNTER >= 1000) THEN
COMMIT;
V_COUNTER := 0;
END IF;
END LOOP;
COMMIT;
END;
⑪ 当需要更新的表是单个或者被更新的字段不需要关联其它表带过来中的数据(例如:外键约束),则选择标准的UPDATE语句,速度最快,稳定性最好,并返回影响条数。如果WHERE条件中的字段加上索引,那么更新效率就更高。但若需要关联表更新字段时,UPDATE的效率就非常差。此时可以采用MERGE且非关联形式高效完成表对表的UPDATE操作。
INSERT
① 将表修改为NOLOGGING模式。
② 暂停索引。
③ 以APPEND模式插入。
④ 加入PARALLEL,采用并行插入。
DELETE
① 利用FORALL完成。
② 利用ROWID或ROW_NUMBER() OVER()高效删除重复记录。
③ 将表修改为NOLOGGING模式。
到此,关于“怎么提高dml的性能”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341