Oracle arraysize的研究是怎样的

63次阅读
没有评论

共计 5775 个字符,预计需要花费 15 分钟才能阅读完成。

Oracle arraysize 的研究是怎样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

SYS@proc desc aaa;

 Name    Null?  Type

 —————————————– ——– —————————-

 ID1      NUMBER(38)

 ID2      NUMBER(38)

 ID3    NUMBER(38)

 ID4    NUMBER(38)

SYS@proc select * from aaa;

 ID1    ID2       ID3  ID4

———- ———- ———- ———-

   1      1          1    1

   1      1         1    0

SYS@proc select * from aaa1;

 ID1   ID2       ID3  ID4

———- ———- ———- ———-

   1      1         1    0

   1      1          1    1

SYS@proc select * from aaa where id1/id2=1 and id3/id4=1;

ERROR:

ORA-01476: divisor is equal to zero

no rows selected

SYS@proc set arraysize 1

SYS@proc /

  ID1    ID2       ID3  ID4

———- ———- ———- ———-

   1      1          1     1

ERROR:

ORA-01476: divisor is equal to zero

SYS@proc select * from aaa1 where id1/id2=1 and id3/id4=1;

select * from aaa1 where id1/id2=1 and id3/id4=1

 *

ERROR at line 1:

ORA-01476: divisor is equal to zero

SYS@proc drop table aaa2 purge;

Table dropped.

SYS@proc create table aaa2 (id1 int,id2 int,id3 int,id4 int,flag int);

Table created.

SYS@proc insert into aaa2 values(1,1,1,1,1);

1 row created.

SYS@proc insert into aaa2 values(1,1,1,1,2);

1 row created.

SYS@proc insert into aaa2 values(1,1,1,1,3);

1 row created.

SYS@proc insert into aaa2 values(1,1,1,1,4);

1 row created.

SYS@proc insert into aaa2 values(1,1,1,1,5);

1 row created.

SYS@proc insert into aaa2 values(1,1,1,1,6);

1 row created.

SYS@proc insert into aaa2 values(1,1,1,1,7);

1 row created.

SYS@proc insert into aaa2 values(1,1,1,1,8);

1 row created.

SYS@proc insert into aaa2 values(1,1,1,1,9);

1 row created.

SYS@proc insert into aaa2 values(1,1,1,1,10);

1 row created.

SYS@proc insert into aaa2 values(1,1,1,0,0);

1 row created.

SYS@proc commit;

Commit complete.

SYS@proc analyze table aaa2 compute statistics;

Table analyzed.

SYS@proc set arraysize 1

SYS@proc select * from aaa2 where id1/id2=1 and id3/id4=1;

 ID1   ID2       ID3      ID4     FLAG

———- ———- ———- ———- ———-

   1      1         1    1       1

   1      1         1     1       2

   1      1         1    1       3

   1      1         1    1        4

   1     1         1    1       5

   1      1         1     1        6

   1      1          1    1       7

   1    1         1    1        8

   1      1          1    1       9

ERROR:

ORA-01476: divisor is equal to zero

9 rows selected.

– 从大量结果上看,arraysize 为 1 或者 2 是一样的。这里为 9 预见。

SYS@proc select * from aaa2;

 ID1    ID2      ID3 ID4    FLAG

———- ———- ———- ———- ———-

   1      1          1    1        1

   1      1          1    1        2

   1      1          1    1        3

   1      1         1    1       4

   1      1          1    1        5

   1      1          1    1       6

   1       1         1    1       7

   1    1    1  1       8

   1      1         1    1       9

   1      1          1    1      10

   1      1          1    0        0

11 rows selected.

SYS@proc

SYS@proc set arraysize 2

SYS@proc select * from aaa2 where id1/id2=1 and id3/id4=1;

 ID1   ID2      ID3 ID4   FLAG

———- ———- ———- ———- ———-

  1     1        1   1      1

  1     1        1   1      2

  1     1        1   1      3

  1     1        1   1      4

  1     1        1   1      5

  1     1        1   1      6

  1     1        1   1      7

  1     1        1   1      8

ERROR:

ORA-01476: divisor is equal to zero

8 rows selected.

语句对应的 10046,可以看出是返回了 9 行,但是从上边看是 8 行,很奇怪。

PARSING IN CURSOR #140496887317072 len=48 dep=0 uid=0 oct=3 lid=0 tim=1514130832420098 hv=3007681721 ad= 812bd000 sqlid= 7cfwyuytnb55t

select * from aaa2 where id1/id2=1 and id3/id4=1

END OF STMT

PARSE #140496887317072:c=0,e=1221,p=0,cr=0,cu=0,mis=1,r=0,dep=0,og=1,plh=2576342259,tim=1514130832420093

EXEC #140496887317072:c=0,e=24,p=0,cr=0,cu=0,mis=0,r=0,dep=0,og=1,plh=2576342259,tim=1514130832420198

WAIT #140496887317072: nam= SQL*Net message to client ela= 5 driver id=1650815232 #bytes=1 p3=0 obj#=-1 tim=1514130832420238

FETCH #140496887317072:c=0,e=64,p=0,cr=2,cu=0,mis=0,r=1,dep=0,og=1,plh=2576342259,tim=1514130832420331

WAIT #140496887317072: nam= SQL*Net message from client ela= 476 driver id=1650815232 #bytes=1 p3=0 obj#=-1 tim=1514130832420842

WAIT #140496887317072: nam= SQL*Net message to client ela= 3 driver id=1650815232 #bytes=1 p3=0 obj#=-1 tim=1514130832420907

FETCH #140496887317072:c=0,e=36,p=0,cr=1,cu=0,mis=0,r=2,dep=0,og=1,plh=2576342259,tim=1514130832420924

WAIT #140496887317072: nam= SQL*Net message from client ela= 146 driver id=1650815232 #bytes=1 p3=0 obj#=-1 tim=1514130832421092

WAIT #140496887317072: nam= SQL*Net message to client ela= 2 driver id=1650815232 #bytes=1 p3=0 obj#=-1 tim=1514130832421137

FETCH #140496887317072:c=0,e=28,p=0,cr=1,cu=0,mis=0,r=2,dep=0,og=1,plh=2576342259,tim=1514130832421151

WAIT #140496887317072: nam= SQL*Net message from client ela= 66 driver id=1650815232 #bytes=1 p3=0 obj#=-1 tim=1514130832421237

WAIT #140496887317072: nam= SQL*Net message to client ela= 2 driver id=1650815232 #bytes=1 p3=0 obj#=-1 tim=1514130832421277

FETCH #140496887317072:c=0,e=26,p=0,cr=1,cu=0,mis=0,r=2,dep=0,og=1,plh=2576342259,tim=1514130832421290

WAIT #140496887317072: nam= SQL*Net message from client ela= 60 driver id=1650815232 #bytes=1 p3=0 obj#=-1 tim=1514130832421369

WAIT #140496887317072: nam= SQL*Net message to client ela= 1 driver id=1650815232 #bytes=1 p3=0 obj#=-1 tim=1514130832421407

FETCH #140496887317072:c=0,e=25,p=0,cr=1,cu=0,mis=0,r=2,dep=0,og=1,plh=2576342259,tim=1514130832421420

WAIT #140496887317072: nam= SQL*Net message from client ela= 410 driver id=1650815232 #bytes=1 p3=0 obj#=-1 tim=1514130832421848

WAIT #140496887317072: nam= SQL*Net message to client ela= 2 driver id=1650815232 #bytes=1 p3=0 obj#=-1 tim=1514130832421907

FETCH #140496887317072:c=0,e=63,p=0,cr=1,cu=0,mis=0,r=1,dep=0,og=1,plh=2576342259,tim=1514130832421956

STAT #140496887317072 id=1 cnt=10 pid=0 pos=1 obj=88977 op= TABLE ACCESS FULL AAA2 (cr=7 pr=0 pw=0 time=94 us cost=2 size=10 card=1)

WAIT #140496887317072: nam= SQL*Net break/reset to client ela= 28 driver id=1650815232 break?=1 p3=0 obj#=-1 tim=1514130832422110

WAIT #140496887317072: nam= SQL*Net break/reset to client ela= 120 driver id=1650815232 break?=0 p3=0 obj#=-1 tim=1514130832422252

WAIT #140496887317072: nam= SQL*Net message from client ela= 595 driver id=1650815232 #bytes=1 p3=0 obj#=-1 tim=1514130832422889

CLOSE #140496887317072:c=0,e=14,dep=0,type=0,tim=1514130832422981

=====================

所以其实 arraysize 是 1 还是 2,还是存在区别的。不过从 10046 上看却是没多大区别,从全表扫描或者其他能够正常返回结果的情况下,值为 1 和 2 是完全一样的。

但是实际上无论 arraysize 的值是多少,默认第一行单独会直接发送反馈给用户的,所以应该是不用设置的。
后边研究的逻辑读也有点问题,在 12C 里边差别更大。

看完上述内容,你们掌握 Oracle arraysize 的研究是怎样的的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注丸趣 TV 行业资讯频道,感谢各位的阅读!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-20发表,共计5775字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)