index fast full scan不能使用並行的實驗

wei-xh發表於2010-07-10
今天同事問我怎麼提高一個查詢的速度,非常著急要查詢結果。查詢語句執行計劃如下:
---------------------------------------------------------------------------------
| Id  | Operation             | Name    | Rows  | Bytes | Cost (%CPU)| Time     |
---------------------------------------------------------------------------------
|   0 | SELECT STATEMENT      |         |     1 |     6 | 52563   (2)| 00:10:31 |
|   1 |  SORT GROUP BY        |         |     1 |     6 |            |          |
|   2 |   INDEX FAST FULL SCAN| PK_IC40 |   540M|   310M| 52563   (2)| 00:10:31 |
---------------------------------------------------------------------------------
透過HINT並行的做法讓查詢時間僅用了10秒。查詢執行計劃:
SQL> SELECT DEGREE FROM user_indexes WHERE index_Name='PK_IC40';

DEGREE
----------------------------------------
1

已用時間:  00: 00: 00.05
SQL> explain plan for
  2  SELECT /*+ parallel_index(ic40 pk_ic40 8)*/COUNT(DISTINCT aac001) FROM ic40;

已解釋。

已用時間:  00: 00: 00.05
SQL> select * from table(dbms_xplan.display);

PLAN_TABLE_OUTPUT
-----------------------------------------------------------------------------------------------------------------------
--------
Plan hash value: 3375479740

----------------------------------------------------------------------------------------------------------------------
| Id  | Operation                    | Name     | Rows  | Bytes | Cost (%CPU)| Time     |    TQ  |IN-OUT| PQ Distrib |
----------------------------------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT             |          |     1 |     6 | 52563   (2)| 00:10:31 |        |   |       |
|   1 |  SORT GROUP BY               |          |     1 |     6 |            |          |        |   |       |
|   2 |   PX COORDINATOR             |          |       |       |            |          |        |   |       |
|   3 |    PX SEND QC (RANDOM)       | :TQ10001 |     1 |     6 |            |          |  Q1,01 | P->S | QC (RAND)  |
|   4 |     SORT GROUP BY            |          |     1 |     6 |            |          |  Q1,01 | PCWP |            |
|   5 |      PX RECEIVE              |          |     1 |     6 |            |          |  Q1,01 | PCWP |            |
|   6 |       PX SEND HASH           | :TQ10000 |     1 |     6 |            |          |  Q1,00 | P->P | HASH       |
|   7 |        SORT GROUP BY         |          |     1 |     6 |            |          |  Q1,00 | PCWP |            |
|   8 |         PX BLOCK ITERATOR    |          |   540M|   310M| 52563   (2)| 00:10:31 |  Q1,00 | PCWC |            |
|   9 |          INDEX FAST FULL SCAN| PK_IC40  |   540M|   310M| 52563   (2)| 00:10:31 |  Q1,00 | PCWP |            |
----------------------------------------------------------------------------------------------------------------------

已選擇16行。

可是突然想起了之前看過一篇文章,說是對於index fast full scan操作,除非在索引上顯式的設定並行度,否則採用HINT新增並行的做法,是不能達到並行效果的。文章連結如下:

我的ORACLE版本,10.2.0.4.

莫非原文的意思是不能夠使用parallel()提示來並行index fast full sacn。而不是說parallel_index()不可以讓index fast full scan並行?


[ 本帖最後由 wei-xh 於 2010-7-10 13:43 編輯 ]

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/22034023/viewspace-667704/,如需轉載,請註明出處,否則將追究法律責任。

相關文章