数据库oracle Oracle在插入大量数据时速度会越来越慢,请问有什么解决办法?
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 删除表数据 线管里的线抽不动怎么办
版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。