知方号

知方号

Oracle在插入大量数据时速度会越来越慢,请问有什么解决办法

Oracle在插入大量数据时速度会越来越慢,请问有什么解决办法?

加快oracle数据库插数据速度方法:

从编程角度考虑:

1 使用绑定变量,达到一次预编译多次执行的效果。如果不使用绑定变量,数据库每次都要对sql进行分析,消耗资源。

2 使用oracle提供的批量接口,这样可以减少网络传输次数,加快效率

3 适当增加commit间隔,commit指令比较消耗数据库资源,尽量多插入一些数据再提交。建议一千条以上。

4 使用hint(如 append),使用insert 语句 nologging选项,减少数据库日志登记。

5 考虑使用多进程插入或者使用并行hint插入

从数据库角度考虑:

1 把表改成nologging模式,这样不用登记回滚日志

2 对表进行分区,让不同分区落在不同硬盘

3 把表的索引删除,插完数据后再恢复

4 增大数据库缓冲区

5 使用ssd存储等高效硬盘作为数据库存储

其他细节:

例如把程序部署到数据库服务器再操作,减少网络消耗

插入数据程序输出日志重定向到硬盘

如果是DML语句的话,需要看执行计划,并根据业务需求是否使用HINT,物理内存可以表空间分离,使磁盘I/O量平均分磁盘,或者扩大SGA,再或者增加物理配置,总之有很多选择!

不存在这个问题

既然是大量数据插入 它是一个批处理 你怎么知道越来越慢的 要么就直接跑几个小时 怎么就越来越啦?

数据插入 无非是加锁 写日志 写热数据 后来定时回盘

如果比以往慢 一般就是还有其他大事务

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至lizi9903@foxmail.com举报,一经查实,本站将立刻删除。