Effective MULTIBLOCK READ COUNT values used in cost calculations
The following effective multiblock read count is the value used by Oracle in the cost calculation in place of the actual parameter value set up in the INIT.ORABelow, the ACT_MBRC represents the actual value set in the INIT.ORA, or changed at the session level
ALTER SESSION SET db_multiblock_read_count = 16;
Here, the value used in calculations is: 10.40
For a table scan, this was calculated using:
ALTER SESSION SET db_multiblock_read_count = 16;
For ROWS/COST = 10000/962 = 10.396
These are constants used across DB versions for the range of values for multiblock read counts:
ACT_MBRC ACT_COST OLD_COST EFF_MBRC
---------- ---------- ---------- ----------
1 76353 128000 1.676
2 48383 64000 2.646
3 37051 42667 3.455
4 30660 32000 4.175
5 26472 25600 4.835
6 23479 21333 5.452
7 21213 18286 6.034
8 19429 16000 6.588
9 17980 14222 7.119
10 16775 12800 7.63
11 15755 11636 8.124
12 14878 10667 8.603
13 14115 9846 9.068
14 13443 9143 9.522
15 12846 8533 9.964
16 12312 8000 10.396
17 11830 7529 10.82
18 11394 7111 11.234
19 10995 6737 11.642
20 10630 6400 12.041
21 10294 6095 12.434
22 9984 5818 12.821
23 9696 5565 13.201
24 9428 5333 13.577
25 9178 5120 13.946
26 8945 4923 14.31
27 8725 4741 14.67
28 8519 4571 15.025
29 8324 4414 15.377
30 8141 4267 15.723
31 7967 4129 16.066
32 7802 4000 16.406
33 7646 3879 16.741
34 7497 3765 17.073
35 7355 3657 17.403
36 7220 3556 17.729
37 7091 3459 18.051
38 6968 3368 18.37
39 6850 3282 18.686
40 6737 3200 19
41 6628 3122 19.312
42 6524 3048 19.62
43 6424 2977 19.925
44 6327 2909 20.231
45 6234 2844 20.533
46 6145 2783 20.83
47 6058 2723 21.129
48 5975 2667 21.423
49 5895 2612 21.713
50 5817 2560 22.004
51 5741 2510 22.296
52 5668 2462 22.583
53 5598 2415 22.865
54 5529 2370 23.151
55 5463 2327 23.43
56 5399 2286 23.708
57 5336 2246 23.988
58 5275 2207 24.265
59 5216 2169 24.54
60 5159 2133 24.811
61 5103 2098 25.083
62 5049 2065 25.352
63 4996 2032 25.62
64 4945 2000 25.885
65 4894 1969 26.154
66 4845 1939 26.419
67 4798 1910 26.678
68 4751 1882 26.942
69 4706 1855 27.199
70 4661 1829 27.462
71 4618 1803 27.718
72 4576 1778 27.972
73 4534 1753 28.231
74 4494 1730 28.482
75 4455 1707 28.732
76 4416 1684 28.986
77 4378 1662 29.237
78 4341 1641 29.486
79 4305 1620 29.733
80 4269 1600 29.984
81 4235 1580 30.224
82 4201 1561 30.469
83 4167 1542 30.718
84 4134 1524 30.963
85 4102 1506 31.204
86 4071 1488 31.442
87 4040 1471 31.683
88 4010 1455 31.92
89 3980 1438 32.161
90 3951 1422 32.397
91 3922 1407 32.636
92 3894 1391 32.871
93 3867 1376 33.101
94 3840 1362 33.333
95 3813 1347 33.569
96 3787 1333 33.8
97 3761 1320 34.034
98 3736 1306 34.261
99 3711 1293 34.492
100 3686 1280 34.726
101 3662 1267 34.954
102 3639 1255 35.174
103 3615 1243 35.408
104 3592 1231 35.635
105 3570 1219 35.854
106 3548 1208 36.077
107 3526 1196 36.302
108 3504 1185 36.53
109 3483 1174 36.75
110 3462 1164 36.973
111 3442 1153 37.188
112 3422 1143 37.405
113 3402 1133 37.625
114 3382 1123 37.847
115 3363 1113 38.061
116 3343 1103 38.289
117 3325 1094 38.496
118 3306 1085 38.717
119 3288 1076 38.929
120 3270 1067 39.144
121 3252 1058 39.36
122 3234 1049 39.579
123 3217 1041 39.789
124 3200 1032 40
125 3183 1024 40.214
126 3166 1016 40.43
127 3150 1008 40.635
128 3134 1000 40.842
这个貌似在哪看过。。。
从查询优化器这个层面来讲,db_multiblock_read_count这个参数设置的越大,优化器越倾向于走全表扫描。Oracle并不怕一次读入多个快,而是害怕跳跃读,非常不幸的是索引读就是跳跃读
值-》索引根-》索引分支、叶子节点取得rowid-》根据rowid获得记录所在的物理位置。我们可以看到跳转了多次。
就使用索引访问记录,与全表扫描本身来讲,本身并没有什么快慢之分。
就1个1万行的表,占用500个块来讲,
如果你取其中一条当然是索引快,
因为只需要3-4次跳转就可以取到数据。
但是如果取其中5000行来讲,就是全表扫描快一些。
因为如果走索引
需要跳转 3-4*5000 大约在15000-20000次,
但是全表扫描的话,如果db_multiblock_read_count设置为16 则需要 5000/16
如果db_multiblock_read_count设置为80 则就是5000/80=1000/16
也就是说db_multiblock_read_count设置的越大,需要多快读的次数就越少。
如果有不对的 请师傅多多指正啊。
页:
[1]