对于一个大的任务,通常的作法是利用一个进程,串行的执行,若是系统资源足够,能够采用parallel技术,把一个大的任务分红若干个小的任务,同时启用n个进程/线程,并行的处理这些小的任务,这些并发的进程称为并行执行服务器(parallel executeion server),这些并发进程由一个称为并发协调进程的进程来管理。sql
启用Parallel前的忠告:只有在须要处理一个很大的任务,如须要几十分钟,几个小时的做业中,而且要有足够的系统资源的状况下(这些资源包括cpu,内存,io),您才应该考虑使用parallel。不然,在一个多并发用户下,系统自己资源负担已经很大的状况下,启用parallel,将会致使某一个会话试图占用了全部的资源,其余会话不得不去等待,从而致使系统系能反而降低的状况,通常状况下,oltp系统不要使用parallel,oltp系统中能够考虑去使用。服务器
Parallel分类session
l 并行查询parallel query并发
l 并行dml parallel dml pdmloracle
l 并行ddl parallel ddl pddlui
1、 并行查询spa
并行查询容许将一个sql select语句划分为多个较小的查询,每一个部分的查询并发地运行,而后将各个部分的结果组合起来,提供最终的结果,多用于全表扫描,索引全扫描等,大表的扫描和链接、建立大的索引、分区索引扫描、大批量插入更新和删除线程
1. 启用并行查询server
SQL> ALTER TABLE T1 PARALLEL;索引
告知oracle,对T1启用parallel查询,但并行度要参照系统的资源负载情况来肯定。
利用hints提示,启用并行,同时也能够告知明确的并行度,不然oracle自行决定启用的并行度,这些提示只对该sql语句有效。
SQL> select /*+ parallel(t1 8) */ count(*)from t1;
SQL> select degree from user_tables where table_name='T1';
DEGREE
--------------------
DEFAULT
并行度为Default,其值由下面2个参数决定
SQL> show parameter cpu
NAME TYPE VALUE
----------------------------------------------- ------------------------------
cpu_count integer 2
parallel_threads_per_cpu integer 2
cpu_count表示cpu数
parallel_threads_per_cpu表示每一个cpu容许的并行进程数
default状况下,并行数为cpu_count*parallel_threads_per_cpu
2. 取消并行设置
SQL> alter table t1 noparallel;
SQL> select degree from user_tables wheretable_name='T1';
DEGREE
----------------------------------------
1
3. 数据字典视图
v$px_session
sid:各个并行会话的sid
qcsid:query coordinator sid,查询协调器sid
2、 并行dml
并行dml包括insert,update,delete,merge,在pdml期间,oracle可使用多个并行执行服务器来执行insert,update,delete,merge,多个会话同时执行,同时每一个会话(并发进程)都有本身的undo段,都是独立的一个事务,这些事务要么由pdml协调器进程提交,要么都rollback。
在一个有充足I/o带宽的多cpu主机中,对于大规模的dml,速度可能会有很大的提高,尤为是在大型的数据仓库环境中。
并行dml须要显示的启用
SQL> alter session enable parallel dml;
Disable并行dml
SQL> alter session disable parallel dml;
3、 并行ddl
并行ddl提供了dba使用所有机器资源的能力,经常使用的pddl有
create table as select ……
create index
alter index rebuild
alter table move
alter table split
在这些sql语句后面加上parallel子句
例
SQL> alter table t1 move parallel;
Table altered
SQL> create index T1_IDX on T1 (OWNER,OBJECT_TYPE)
2 tablespace SYSTEM
3 parallel;
4 ;