测试SQLPLUS的ARRAYSIZE对性能的影响
来源:互联网 发布:淘宝拓客助手怎么样 编辑:程序博客网 时间:2024/05/15 06:29
这个过程就是统计信息中的SQL*Net roundtrips to/from client。
因为arraysize 默认是15行,那么就有一个问题,因为我们一个block中的记录数一般都会超过15行,所以如果按照15行扫描一次,那么每次扫描要多扫描一个数据块,一个数据块也可能就会重复扫描多次。
重复的扫描会增加consistent gets 和 physical reads。 增加physical reads,这个很好理解,扫描的越多,物理读的可能性就越大。
consistent gets,这个是从undo里读的数量,Oracle 为了保证数据的一致性,当一个查询很长,在查询之后,数据块被修改,还未提交,再次查询时候,Oracle根据Undo 来构建CR块,这个CR块,可以理解成数据块在之前某个时间的状态。 这样通过查询出来的数据就是一致的。
那么如果重复扫描的块越多,需要构建的CR块就会越多,这样读Undo 的机会就会越多,consistent gets 就会越多。
如果数据每次传到客户端有中断,那么这些数据会重新扫描,这样也就增加逻辑读,所以调整arraysize可以减少传的次数,减少逻辑读。
所以通过上面的说明,arraysize 参数如果过低,会影响如physical reads,consistent gets 还有SQL*Net roundtrips to/from client次数。 ---本段引自DAVE博客。
实验结论:实验用表是由dba_objects;创建。通过设置arraysize为1、15、200,可以通过最后的汇总表格得出将arraysize设置为200,可以得到更好的查询性能。
具体表现在:SQL语句执行时间大幅减少,通过Oracle Net从客户端收到的字节总数大幅减少,SQL * Net发送和从客户端接收的字节总数大幅减少--减幅比例接近arraysize尺寸的比例。
所以在使用SQLPLUS客户端查取大数据、SPOOL输出时,可以考虑将arraysize设置的大一点,提高性能。永久设置此参数可以在$ORACLE_HOME/sqlplus/admin/glogin.sql中写入set arraysize 15 这样。
1,使用SQLPLUS的ARRAYSIZE默认值15来进行测试
BYS@bys1>create tabele test2 as select * from dba_objects;
BYS@bys1>alter system flush shared_pool;
System altered.
BYS@bys1>alter system flush buffer_cache;
System altered.
BYS@bys1>set arraysize 15 因为我已经更改过,所以手动再改为默认的15
此设置只在当前SESSION中有用,如果需要永久设置,可以在$ORACLE_HOME/sqlplus/admin/glogin.sql中写入set arraysize 15 这样。
BYS@bys1>select * from test2;
72465 rows selected.
Elapsed: 00:00:02.12
----------------------------------------------------------
606 recursive calls
0 db block gets
5882 consistent gets
1052 physical reads
0 redo size
8036433 bytes sent via SQL*Net to client
53549 bytes received via SQL*Net from client
4832 SQL*Net roundtrips to/from client
6 sorts (memory)
0 sorts (disk)
72465 rows processed
汇总:执行时间:02.12秒,606次递归调用,5882 一致读,1052 物理读,8036433 bytes发送,53549 bytes接收,4832次往返
2.将SQLPLUS的ARRAYSIZE值设置为200
BYS@bys1>alter system flush buffer_cache;
System altered.
BYS@bys1>alter system flush shared_pool;
System altered.
BYS@bys1>set arraysize 200
BYS@bys1>set autotrace traceonly stat 只显示统计信息不显示输出结果
BYS@bys1>select * from test2;
72465 rows selected.
Elapsed: 00:00:00.62
Statistics
----------------------------------------------------------
606 recursive calls
0 db block gets
1491 consistent gets
1049 physical reads
0 redo size
7455593 bytes sent via SQL*Net to client
4401 bytes received via SQL*Net from client
364 SQL*Net roundtrips to/from client
6 sorts (memory)
0 sorts (disk)
72465 rows processed 汇总:执行时间:00.62秒,606次递归调用,1491一致读,1049物理读,7455593 bytes发送,4401 bytes接收,364次往返
3.将SQLPLUS的ARRAYSIZE值设置为1
BYS@bys1>alter system flush buffer_cache;System altered.
BYS@bys1>alter system flush shared_pool;
System altered.
BYS@bys1>set autotrace traceonly stat
BYS@bys1>set arraysize 1
BYS@bys1>select * from test2;
72465 rows selected.
Elapsed: 00:00:08.71
Statistics
----------------------------------------------------------
606 recursive calls
0 db block gets
36830 consistent gets
1049 physical reads
0 redo size
12118659 bytes sent via SQL*Net to client
398971 bytes received via SQL*Net from client
36234 SQL*Net roundtrips to/from client
6 sorts (memory)
0 sorts (disk)
72465 rows processed
汇总:执行时间:08.71秒,606次递归调用,36830一致读,1049物理读,12118659 bytes发送,398971bytes接收,36234次往返
三种参数的性能汇总表格如下:
- 测试SQLPLUS的ARRAYSIZE对性能的影响
- arraysize 对性能的影响
- Arraysize的设置以及对查询性能的影响
- Session对性能测试的影响
- Session对性能测试的影响
- 影响SQLPLUS性能的几个参数
- 测试IDServer的性能以及加锁对性能的影响
- GraphicsMagick性能测试(二) - 开启多线程对性能的影响
- [原创]Apache Rewrite对apache性能影响的测试
- [原创]Apache Rewrite对apache性能影响的测试
- [原创]Apache Rewrite对apache性能影响的测试
- 如何减小大量写log对性能测试的影响
- CUFFT中FFT点数对FFT性能的影响测试
- CPU超频与电源设置对性能测试的影响
- 润乾集算报表层次数据集对性能的影响测试
- CUFFT中FFT点数对FFT性能的影响测试
- 关于SQLite索引对写入性能影响的测试
- sysbench工具测试query cache对性能的影响
- Pro Android学习笔记(四七):Dialog(4):一些补充和思考
- IUnKNown接口——QueryInterface函数
- Spring mvc中log4j的配置与使用
- JNI调用
- win7计算机管理 资源管理器停止工作
- 测试SQLPLUS的ARRAYSIZE对性能的影响
- asp.net页面处理流程 - 处理 PostBack回来的数据 - LoadAllState 和 ProcessPostData
- 排序算法总结
- JMS无法消费消息原因:
- Linux系列- 文件系统、挂载管理
- 第十一周项目3-3-1000以内的完数
- 浅谈单例模式
- jsp 页面中文 传到后台 乱码问题解决
- fatal error LNK1104: cannot open file ‘..../lib.obj