2016 - 2024

感恩一路有你

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

浏览量:2571 时间:2021-03-14 11:07:52 作者:admin

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

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

从编程角度考虑:

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

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

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

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

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

从数据库角度考虑:

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

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

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

4 增大数据库缓冲区

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

其他细节:

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

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

Oracle大数据量导入,中途停止了,是怎么回事?

oracle中 HWM高水位不会因为delete而下降, 那么虽然你DELETE了很多数据,但是全表扫描还是要扫描到HWM 下的所有数据块。

但是对于经常插入和删除的日志表,这样是正常的,因为你回收了空间后,它又会增长上去,回收空间的意义很小。

除非是那种删除后不再插入数据的表, 可以考虑用ALTER TABLE MOVE / SHRINK SPACE的方法来回收空间。

Oracle批量数据插入60000条以上,速度变的很慢,而且中间会断。求解决方案?

分批次提交比如5000条提交一次。要是可以的话建议用sqlloader插入

数据库oracle oracle 删除表数据 线管里的线抽不动怎么办

版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。