调试经验——提高SQLPLUS中导出数据(Spool)的速度的方法(set arraysize 5000)

问题描述:

通过SQLPLUS查询数据集并导出到Excel文件,发现速度非常慢(50分钟只导出10M数据,共17万行,每行两列)。

然后,百度了一下解决方案,运气不错,很快就找到了一篇文章:https://www.2cto.com/database/201311/254469.html

然后,将arraysize设置为更大值,发现两分钟就能导出数据,比Toad还快了很多,大大超过我的预期!

 

解决方案:

set arraysize 5000

默认值为15,最大可设置为5000。不同arraysize对导出速度的影响见如下对比(基于我的实测数据):

Arraysize用时(分钟)导出行数每分钟导出行数
154910849221.41
300490002250
500022451

12290.5

简单算算即知,通过将Arraysize设置为最大值5000,相比默认值15,每分钟导出行数足足提升了55倍!简直是天壤之别!

参考文章:

https://docs.oracle.com/cd/E11882_01/server.112/e16604/apa.htm#SQPUG141

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值