并行执行是同时开启多个进程/线程来完成同一个任务,并行执行的每一个进程/线程都会消耗额外的硬件资源,所以并行执行的本质就是以额外的硬件资源消耗来换取执行时间的缩短。这里的额外硬件资源消耗是指对数据库服务器上多个CPU、内存、从个I/O通道,甚至是RAC环境下多个数据库节点的额外利用。

下面总结一下Oracle里开启并行的几种方法

1、更改目标表的并行度

有两种方法修改目标表的并行度

  • alter table table_name parallel;

  • alter table table_name parallel n;

其中方法1 是把指定表的并行度修改为默认值,方法2是把指定表的并行度修改为n;

查看表EMP当前的并行度为1

scott@TEST>select table_name,degree from user_tables where table_name='EMP';

TABLE_NAME		       DEGREE
------------------------------ ----------
EMP					1

想用默认的并行度去访问表EMP

scott@TEST>alter table emp parallel;

Table altered.

scott@TEST>select table_name,degree from user_tables where table_name='EMP';

TABLE_NAME		       DEGREE
------------------------------ ----------
EMP				  DEFAULT

scott@TEST>set autotrace traceonly
scott@TEST>select * from emp;

14 rows selected.


Execution Plan
----------------------------------------------------------
Plan hash value: 2873591275

--------------------------------------------------------------------------------------------------------------
| Id  | Operation	     | Name	| Rows	| Bytes | Cost (%CPU)| Time	|    TQ  |IN-OUT| PQ Distrib |
--------------------------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT     |		|    14 |  1218 |     2   (0)| 00:00:01 |	 |	|	     |
|   1 |  PX COORDINATOR      |		|	|	|	     |		|	 |	|	     |
|   2 |   PX SEND QC (RANDOM)| :TQ10000 |    14 |  1218 |     2   (0)| 00:00:01 |  Q1,00 | P->S | QC (RAND)  |
|   3 |    PX BLOCK ITERATOR |		|    14 |  1218 |     2   (0)| 00:00:01 |  Q1,00 | PCWC |	     |
|   4 |     TABLE ACCESS FULL| EMP	|    14 |  1218 |     2   (0)| 00:00:01 |  Q1,00 | PCWP |	     |
---------------------------------------