我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎么提高dml的性能

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎么提高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

怎么提高dml的性能

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

怎么提高电脑性能

小编给大家分享一下怎么提高电脑性能,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!具体操作:1.点击左下角的搜索,搜索“控制面板”,点击进入。2.在查看方式处选择「
2023-06-27

Javascript之怎么提高React性能

本篇内容主要讲解“Javascript之怎么提高React性能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Javascript之怎么提高React性能”吧!1.解决重复渲染问题我们大多数人都知
2023-07-05

win10怎么提高显卡性能

今天小编给大家分享一下win10怎么提高显卡性能的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。win10提高显卡性能的设置教
2023-07-01

Cassandra中怎么提高性能和扩展性

要提高Cassandra的性能和扩展性,可以考虑以下几点:数据建模优化:设计合理的数据模式,避免数据倾斜和冗余,优化查询性能。分区键选择:选择合适的分区键,避免数据热点,分散数据存储在集群中的节点上,提高负载均衡性能。副本策略设置:合理设置
Cassandra中怎么提高性能和扩展性
2024-03-15

使用Swoole怎么提高Laravel性能

使用Swoole怎么提高Laravel性能?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。环境1:硬件: 1 CPU, 4 Cores, 16GB MemoryMacOS 1
2023-06-15

虚拟主机性能怎么提高

要提高虚拟主机的性能,可以采取以下几个方法:1. 优化网站代码:对网站代码进行优化,包括压缩图片、合并CSS和JavaScript文件、使用缓存等,以减少网站的加载时间。2. 使用缓存技术:使用缓存技术可以减少服务器的负载,提高网站的响应速
2023-08-26

mongodb并发读性能怎么提高

要提高MongoDB的并发读性能,可以考虑以下几个方面的优化:数据模型设计:合理设计数据模型,将相关的数据放在同一个文档中,避免频繁的查询和多次读取。索引优化:通过创建合适的索引,可以加快读取操作的速度。根据查询频率和查询条件,选择适当的索
2023-10-26

后端接口怎么提高性能

本篇内容主要讲解“后端接口怎么提高性能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“后端接口怎么提高性能”吧!1. MySQL查询慢是什么体验?谢邀,利益相关。大多数互联网应用场景都是读多写少,
2023-06-15

win10系统怎么提高电脑性能

以下是一些提高Windows 10电脑性能的方法:1. 清理磁盘空间:删除不需要的文件和程序,使用磁盘清理工具或第三方软件进行清理。2. 禁用启动项:打开任务管理器,禁用不必要的启动项,以减少系统启动时的负荷。3. 禁用特效:打开“系统属性
2023-09-12

怎么提高.NET垃圾回收性能

本篇内容介绍了“怎么提高.NET垃圾回收性能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!对于GC垃圾回收,很多人不会陌生。我们这里讲的是提
2023-06-17

mongodb并发读取性能怎么提高

要提高 MongoDB 的并发读取性能,可以考虑以下几个方面:使用索引:在需要频繁读取的字段上创建索引,以加快查询速度。分片:将数据水平切分成多个分片,使数据分布在多个节点上,从而提高并发读取能力。优化查询语句:避免不必要的全表扫描,尽量使
2023-10-27

怎么使用Redis的管道来提高性能

在Redis中使用管道可以显著提高性能,因为它允许客户端在一次网络往返中发送多个命令,而不是每个命令都需要单独的网络往返。这样可以减少网络延迟,并且可以在一次请求中处理多个命令,减少了服务器的处理时间。要使用Redis的管道功能,首先需要
怎么使用Redis的管道来提高性能
2024-05-07

编程热搜

目录