(把以前写的一点简单东西转在Blog上)
初始化参数db_file_multiblock_read_count 影响Oracle在执行全表扫描时一次读取的block的数量.
db_file_multiblock_read_count的设置要受OS最大IO能力影响,也就是说,如果你系统的硬件IO能力有限,即使设置再大的db_file_multiblock_read_count也是没有用的。
理论上,最大db_file_multiblock_read_count和系统IO能力应该有如下关系:
Max(db_file_multiblock_read_count) = MaxOsIOsize/db_block_size
当然这个Max(db_file_multiblock_read_count)还要受Oracle的限制,
目前Oracle所支持的最大db_file_multiblock_read_count 值为128.
我们可以通过db_file_multiblock_read_count来测试Oracle在不同系统下,单次IO最大所能读取得数据量:
我们可以看到,在以上测试平台中,Oracle最多每次IO能够读取128个Block,由于block_size为8k,也就是每次最多读取了1M数据.
$ sqlplus "/ as sysdba" SQL*Plus: Release 10.1.0.2.0 - Production on Wed Aug 11 23:43:52 2004 Copyright (c) 1982, 2004, Oracle. All rights reserved.
SYS AS SYSDBA on 11-AUG-04 >show parameter read_count NAME TYPE VALUE SYS AS SYSDBA on 11-AUG-04 >create tablespace dfmbrc Tablespace created. SYS AS SYSDBA on 11-AUG-04 >create table t tablespace dfmbrc as select * from dba_objects; Table created. SYS AS SYSDBA on 11-AUG-04 >insert into t select * from t; 9149 rows created. SYS AS SYSDBA on 11-AUG-04 >/ 18298 rows created. SYS AS SYSDBA on 11-AUG-04 >/ 36596 rows created. SYS AS SYSDBA on 11-AUG-04 >commit; Commit complete. SYS AS SYSDBA on 11-AUG-04 >alter session set db_file_multiblock_read_count=1000; Session altered. SYS AS SYSDBA on 12-AUG-04 >show parameter read_count NAME TYPE VALUE
Session altered. SYS AS SYSDBA on 11-AUG-04 >alter system flush buffer_cache; System altered. SYS AS SYSDBA on 11-AUG-04 >select count(*) from t; COUNT(*) SYS AS SYSDBA on 12-AUG-04 >@gettrace TRACE_FILE_NAME
|
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。




