对于一个大的任务,一般的做法是利用一个进程,串行的执行,如果系统资源足够,可以采用parallel技术,把一个大的任务分成若干个小的任务,同时启用n个进程/线程,并行的处理这些小的任务,这些并发的进程称为并行执行服务器(parallel executeion server),这些并发进程由一个称为并发协调进程的进程来管理。启用Parallel前的忠告:只有在需要处理一个很大的任务,如需要几十分钟,几个小时的作业中,并且要有足够的系统资源的情况下(这些资源包括cpu,内存,io),您才应该考虑使用parallel。否则,在一个多并发用户下,系统本身资源负担已经很大的情况下,启用parallel,将会导致某一个会话试图占用了所有的资源,其他会话不得不去等待,从而导致系统系能反而下降的情况,一般情况下,oltp系统不要使用parallel,oltp系统中可以考虑去使用。

Parallel分类l  并行查询parallel queryl  并行dml parallel dml pdmll  并行ddl parallel ddl pddl

一、 并行查询并行查询允许将一个sql select语句划分为多个较小的查询,每个部分的查询并发地运行,然后将各个部分的结果组合起来,提供最终的结果,多用于全表扫描,索引全扫描等,大表的扫描和连接、创建大的索引、分区索引扫描、大批量插入更新和删除

1.    启用并行查询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    2parallel_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_sessionsid:各个并行会话的sidqcsid:query coordinator sid,查询协调器sid

二、 并行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并行dmlSQL> alter session disable parallel dml;

三、 并行ddl并行ddl提供了dba使用全部机器资源的能力,常用的pddl有create table as select ……create indexalter index rebuildalter table movealter table split在这些sql语句后面加上parallel子句例SQL> alter table t1 move parallel;Table alteredSQL> create index T1_IDX on T1 (OWNER,OBJECT_TYPE) 2   tablespace SYSTEM3        parallel;4        ;1.  用途强行启用并行度来执行当前SQL。这个在Oracle 9i之后的版本可以使用,之前的版本现在没有环境进行测试。也就是说,加上这个说明,可以强行启用Oracle的多线程处理功能。举例的话,就像电脑装了多核的CPU,但大多情况下都不会完全多核同时启用(2核以上的比较明显),使用parallel说明,就会多核同时工作,来提高效率。但本身启动这个功能,也是要消耗资源与性能的。所有,一般都会在返回记录数大于100万时使用,效果也会比较明显。2.  语法/*+parallel(table_short_name,cash_number)*/这个可以加到insert、delete、update、select的后面来使用(和rule的用法差不多,有机会再分享rule的用法)开启parallel功能的语句是:alter session enable parallel dml;这个语句是DML语句哦,如果在程序中用,用execute的方法打开。3.  实例说明用ERP中的transaction来说明下吧。这个table记录了所有的transaction,而且每天数据量也算相对比较大的(根据企业自身业务量而定)。假设我们现在要查看对比去年一年当中每月的进、销情况,所以,一般都会写成:select to_char(transaction_date,'yyyymm') txn_month,sum(decode(sign(transaction_quantity),1,transaction_quantity,0)) in_qty,sum(decode(sign(transaction_quantity),-1,transaction_quantity,0)) out_qtyfrom mtl_material_transactions mmtwhere transaction_date >= add_months(to_date(    to_char(sysdate,'yyyy')||'0101','yyyymmdd'),-12)and transaction_date <= add_months(to_date(to_char(sysdate,'yyyy')||'1231','yyyymmdd'),-12)group by to_char(transaction_date,'yyyymm') 这个SQL执行起来,如果transaction_date上面有加index的话,效率还算过的去;但如果没有加index的话,估计就会半个小时内都执行不出来。这是就可以在select 后面加上parallel说明。例如:
select /*+parallel(mmt,10)*/to_char(transaction_date,'yyyymm') txn_month,...这样的话,会大大提高执行效率。如果要将检索出来的结果insert到另一个表tmp_count_tab的话,也可以写成:
insert /*+parallel(t,10)*/into tmp_count_tab(txn_month,in_qty,out_qty)select /*+parallel(mmt,10)*/to_char(transaction_date,'yyyymm') txn_month,...插入的机制和检索机制差不多,所以,在insert后面加parallel也会加速的。关于insert机制,这里暂不说了。
Parallel后面的数字,越大,执行效率越高。不过,貌似跟server的配置还有oracle的配置有关,增大到一定值,效果就不明显了。所以,一般用8,10,12,16的比较常见。我试过用30,发现和16的效果一样。不过,数值越大,占用的资源也会相对增大的。如果是在一些package、function or procedure中写的话,还是不要写那么大,免得占用太多资源被DBA开K。4.  Parallel也可以用于多表多表的话,就是在第一后面,加入其他的就可以了。具体写法如下:/*+parallel(t,10) (b,10)*/5.  小结关于执行效率,建议还是多按照index的方法来提高效果。Oracle有自带的explan road的方法,在执行之前,先看下执行计划路线,对写好的SQL tuned之后再执行。实在没办法了,再用parallel方法。Parallel比较邪恶,对开发者而言,不是好东西,会养成不好习惯,导致很多bad SQL不会暴漏,SQL Tuning的能力得不到提升。我有见过某些人create table后,从不create index或primary key,认为写SQL时加parallel就可以了。

Oracle Parallel 多线程相关推荐

  1. oracle 12c 多线程,Oracle 12c(12.1)中性能优化功能增强之通过参数THREADED_EXECTION使用多线程模型...

    1.  后台 UNIX/Linux系统上,Oracle用多进程模型.例如:linux上一个常规安装的数据库会有如下进程列: $ ps -ef | grep [o]ra_ oracle  15356  ...

  2. r语言 不同长度 list 转 dataframe_解决R效率问题—parallel多线程启动

    很多用R的小伙伴可能会抱怨R的效率问题,尤其是处理海量数据的时候.如果你确实这样认为,那是因为你大概不知道R也有多线程之说... R 提供各种各样的包以解决并行处理问题,其中snow包是最典型的之一. ...

  3. Oracle Parallel Query

    Oracle Parallel Query(OPQ)可以将一个SQL statement分成多个片(chunks),然后在独自的CPU上通过多个process(子查询)进行并行运行.每个子查询同时读取 ...

  4. Oracle Parallel Query(OPQ)

    日月明王BLOG   http://sunmoonking.spaces.live.com      Oracle Parallel Query(OPQ)可以将一个SQL statement分成多个片 ...

  5. 什么叫Oracle Parallel模式

    什么叫Oracle Parallel模式 Oracle Parallel用法Oracle技术 2011-03-23 15:51:08 阅读105 评论0 字号:大中小 订阅 . 一.Parallel ...

  6. Oracle Parallel使用

    Oracle Parallel使用 oracle 并行(Parallel)使用 1.查询 Sql代码   SELECT /*+ Parallel(t,8) */ * FROM emp t;   SEL ...

  7. Oracle Parallel模式

    一.Parallel 1. 用途 强行启用并行度来执行当前SQL.这个在Oracle 9i之后的版本可以使用,之前的版本现在没有环境进行测试.也就是说,加上这个说明,可以强行启用Oracle的多线程处 ...

  8. oracle parallel 并行 设置 理解

    引子:以前一直没太关注oracle并行这个特性.前几天一个兄弟碰到的一个问题,才让我觉得这个东西还是有很多需要注意的地方,有必要仔细熟悉下.其实碰到的问题不复杂: 类似如下的一条语句:insert i ...

  9. oracle expdp 多线程,Oracle expdp 过滤和并行

    写在前面的话: 我们知道调用数据泵的方式可以有3种,在这里我绝对不会使用命令行而是首推脚本方式 放弃命令行的理由大概有这些: ① 操作系统对CLI字符数的限制 ② 令人痛恨的转义符 ③ 无法跨平台重用 ...

最新文章

  1. MySQL数据库自连接查询inner join ... on
  2. xftp连接海康摄像头报错:sftp子系统申请已拒绝 请确保ssh连接的sftp子系统设置有效
  3. 导出oracle sequences,CSS_oracle导出序列方法分析,方法一:SELECT ' CREATE SEQUEN - phpStudy...
  4. API Gateway——KONG简单入门
  5. 人工智能诗歌写作平台_人工智能教作文,只写出二类文,人类语文老师稳赢
  6. python半圆代码_趣味项目:用Python代码做个月饼送给你!
  7. ubuntu 上的python不能解析jpeg,png?
  8. 人人商城生成app教程_人人商城打包app教程 方法 hbuilder打包支持支付宝微信原生支付...
  9. 中国高校改名(总结篇)(转载)
  10. 各大网站的wap站页面
  11. 国美易卡借助互联网,国美易卡搭建风控、运营、营销体系
  12. 大数据挖掘机器学习人工智能的维恩图战争
  13. Introduce MBT tool robogenerator
  14. vsftpd详细配置
  15. java swf,SWF文件结构大解剖
  16. 计算机基础公开课课件比赛,计算机基础公开课课件.ppt
  17. 调试组件USMART的学习
  18. IC卡(M1卡)梯控日期的算法解析和计算
  19. [多活] 分布式、多活数据中心如何实现DNS域名解析和负载均衡?
  20. 交通类SCI顶级期刊排名

热门文章

  1. IC验证培训——实战SV验证学习(lab5)
  2. Windows 版本的 B站 开源了?
  3. 研究生体检色弱计算机专业,考研体检,轻度色弱会不会被刷
  4. 企业如何落地实施研发效能度量?
  5. 大连海事大学第一届“启航杯”DLMU CTF部分题解
  6. linux驱动调试--段错误之oops信息分析
  7. Python解析URL参数的方法
  8. PostprocessVolume后期处理效果
  9. FAFU OJ 删除子串
  10. oracle bulk collect into,BULK COLLECT INTO