[20181109]12c sqlplus rowprefetch参数5.txt

[20181109]12c sqlplus rowprefetch参数5.txt


--//这几天一直在探究设置sqlplus参数rowprefetch与arraysize的关系,有必要做一些总结以及一些小更正:


1.设置rowprefetch < arraysize 的情况最佳,因为这样fetch的模式是

rowprefetch,arraysize,arraysize,,...,剩下的记录.

--//比较符合需要的情况.


2.不建议设置rowprefetch >= arraysize的情况.因为这样改变fetch的模式.


rowprefetch,(floor(rowprefetch/arraysize)+1)*arraysize,(floor(rowprefetch/arraysize)+1)*arraysize,...,剩下的记录.


3.补充一点做1点点小小的更正.

--//计算公式不是ceil(rowprefetch/arraysize)*arraysize,而是(floor(rowprefetch/arraysize)+1)*arraysize.

--//这样对于rowprefetch < arraysize该公式也适用.


4.补充例子说明:

--//测试 rowprefetch = arraysize的情况

SCOTT@78> @ver1

PORT_STRING                    VERSION        BANNER

------------------------------ -------------- --------------------------------------------------------------------------------

x86_64/Linux 2.4.xx            11.2.0.4.0     Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production

--//数据库11.2.0.4.但是我使用12c sqlplus做为客户端,rowprefetch参数可以设置,测试一样有效.


SCOTT@78>create table t as select rownum id1,1 id2 from dual connect by level<=23;

Table created.


grant EXECUTE ON  dbms_lock to scott;


CREATE OR REPLACE FUNCTION SCOTT.sleep (seconds IN NUMBER)

   RETURN NUMBER

AS

BEGIN

   sys.DBMS_LOCK.sleep (seconds);

   RETURN seconds;

END;

/


R:> cat aa.txt

set timing on

set arraysize &1

set rowprefetch &2

alter session set events '10046 trace name context forever, level 12';

select rownum  ,t.*,sleep(id2) n10,&&1 arraysize ,&&2 rowprefetch from t;

--select rownum  ,emp.*,get_dept(deptno) c10,&&1 arraysize ,&&2 rowprefetch from emp;

alter session set events '10046 trace name context off';

set timing off


--//执行脚本时,第1个参数表示arraysize,第2个参数表示rowprefetch.


SCOTT@78> @ aa.txt 5 5

Session altered.


$ grep FETCH /u01/app/oracle/diag/rdbms/book/book/trace/book_ora_22631.trc | grep plh=2402761124

FETCH #140395096751240:c=0,e=5005000,p=0,cr=3,cu=0,mis=0,r=5,dep=0,og=1,plh=2402761124,tim=1541729295424586

FETCH #140395096751240:c=2000,e=10010448,p=0,cr=1,cu=0,mis=0,r=10,dep=0,og=1,plh=2402761124,tim=1541729305494803

FETCH #140395096751240:c=1000,e=8007876,p=0,cr=1,cu=0,mis=0,r=8,dep=0,og=1,plh=2402761124,tim=1541729313586610


--//fetch 5,10,8. 而显示行数5,10,8.

--//也就是rowprefetch=arraysize,第2次fetch是 2*arraysize.

--//这样上面的公式也满足要求.(floor(rowprefetch/arraysize)+1)*arraysize


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/267265/viewspace-2219334/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/267265/viewspace-2219334/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值