日期:2014-05-16  浏览次数:20885 次

《Pro Oracle SQL》Chapter3--3.1 Full Scan Access Methods 之二

Full Scans and Throwaway? 全扫描和“抛弃”
??? Always remember that whether or not a full scan will be an effective choice depends on the number of
blocks that will need to be read as much as on how many rows will end up in the final result set.? How
the data is stored plays an important role in the decision, as demonstrated in this example.? However,
the other key factor in whether or not a full scan is an effective choice is throwaway.? Throwaway rows
are those rows that are checked against a filter predicate and don’t match the filter and are thus
rejected from the final result set.

??? 永远记住全扫描是否是有效的选择取决于所需读入的块数,也就是有多少行集将影响最终结果集。数据如何存储在抉择的过程中扮演了重要的角色,正如本例中所演示的。然而,是否全扫描是一个有效的选择的另个关键的因素则是“抛弃”。抛弃行是指这些行由过滤器谓词检查,且不匹配过滤器,则被排除于最终的结果集中。
???? In the previous example, the full table scan operation would have to check all 10,000 rows in the
table and throw away 9,900 of them to end up with the final result set of 100 rows.? The check on each
row is simply the filter predicate on? id = 1 (seen in Listing 3-4 in the Predicate Information section
for step 1).? In order to execute this filter, the CPU will be utilized for each check.? That means that while
the number of blocks accessed will be limited, there will be quite a bit of CPU resources used to
complete the filter checks for each row.? The use of the CPU will be factored into the cost of the full scan. As the number of blocks accessed and the amount of throwaway increases, the more costly the full
scan will become.? Listing 3-5 is a simple query to show the number of rows and number of blocks for
table T2 in your example.? Based on the number of blocks shown, the full table scan would access
approximately 164 blocks.
??? 在上个例子中,全表扫描操作将必须检查表中所有的10000行然后抛弃其中9900行而最终结果集是100行。对每行的检查简单的由过滤谓词id=1(查 看列表3-4的步骤1谓词信息段)。为了执行该过滤器,在每次检查中都要用到CPU。这意味着即使访问的块数是有限的,对于完成每行的检查依然要占用很大CPU资源。CPU的使用将算入全扫描成本中。 因为访问的块数和抛弃的数量的增加,全扫描的成本也越发变高。列表3-5是一个简单的查询展示例子中T2表的行数和块数。基于展示的块数,全表扫描将大概访问164个块。
Listing 3-5. Rows and Blocks Statistics for Tables T1 and T2?????? 表T1和T2的行和块统计
SQL> select table_name, num_rows, blocks from user_tables where table_name = 'T2' ;
?
TABLE_NAME??????????????????????????? NUM_ROWS????????? BLOCKS
------------------------------???????????? ---------------?????????????? ---------------
T2????????????????????????????????????? ? ? ? 10000????????? ? ? ? ? ? ? ? 164
?
1 rows selected.
?
??? Over time, as rows are added to the table and the table grows larger, the cost of throwing away so
many rows would increase enough to cause the optimizer to switch to an index scan operation instead.?
The point where the optimizer decides to switch over may not necessarily be the point where you
achieve optimal performance.
? You can use hints to force the optimizer to use an index and test to see at
what point it might make more sense to use an index,? and if the optimizer doesn’t choose that path,you
can consider using hints or SQL profiles to help.?
Chapter 16 will cover using hints and profiles so
you’ll be prepared to use them if you ever need to do so.
??? 随着时间的推移,行加入表中,表变得越来越大,抛弃如此多的行的成本将迫使优化器切换成索引扫描操作来代替。优化器决定切换的那个(转折)点可能也不一定是你取得优化性能的那个(转折)点。 你能通过提示而强制优化器使用索引,再测试看在哪一点可能使用索引更合理,若优化器不选择那条路径,你就可以考虑使用 提示或者SQL配置参数予以辅助。 第十六章将讲述使用提示和配置,如果你曾经有需要这么做你将用的上他们。

Full Scans and Multiblock Reads??? 全扫描和多块读

??? Another thing y