关于并行的使用,我原来所在研发部门(Real-World Performance)的同事陈焕生已经写了3篇非常棒的“深入理解”系列,可以说并行的精华部分都已经涵盖。
然而,对于大部分SQL开发者和DBA来说,并行的一些最基本的使用方法还没有完全掌握,我着重介绍一下并行使用的常见问题及注意事项。
1、什么时候使用并行?
常见的场景有:
a)
普通SQL最常见的情况就是大表的全表扫描,还有就是大的索引的快速全扫描(注意,index fast full scan可以使用并行,index full scan 不能使用并行)。
需要纠正一个误区:SQL执行慢就可以通过使用并行或是增加并行来提高速度。
正解:并行能否发挥作用要看SQL的具体执行计划,比如标量子查询或是DB link,增大并行带来的性能提升是微乎其微的!
多大的表算大表?
至少要百万级以上记录的表吧。如果几亿甚至十几亿记录数的表全表扫描不使用并行,SQL的执行时间会相当长,特别是表在SQL执行的过程中如果还有其他session的DML操作的时候。
OLTP系统的正常事务一般不会使用大表全扫描的执行计划,如果有一些统计分析的业务,建议在系统资源相对空闲的时候开启并行。
b)
用create table As Select创建一张大表,如
create table test parallel 16 as select .... from t1,t2 where .....;
alter table test noparallel;
c)
创建或重建索引
create ind