oracle  并行执行

所谓并行执行,是指能够将一个大型串行任务(任何DML,一般的DDL)物理的划分为叫多个小的部分,这些较小的部分可以同时得到处理。

何时使用并行执行:

1、必须有一个非常大的任务

2、必须有充足的资源(CPU,I/O,MEMORY)

并行查询

并行查询允许将一个SQL SELECT 语句划分为多个较小的查询,每个查询并发的运行。最后将每个较小查询得到的结果组合起来,得到最终结果。

启动并行查询几种方式:

1、在查询中使用一个hint提示:select /*+ parallel(4)  */  count(*)  from test_a ;---指定一个并行度为4的并行查询。

2、利用alter table修改表:

  • alter table test_a parallel 4;--告诉oracle,在创建这个表的执行计划时,使用并行度4
  • alter table test_a parallel;--告诉oracel,“请考虑并行执行。”oracle 会根据系统工作负载和查询本身来确定适当的并行度。资源充足,并行度上升,资源稀缺,并行度下降。oracle能动态的增加或减少查询所需要的并发资源量。                 ---更喜欢用此种方式启动并行查询。

通过一个并行查询的执行计划观察并行查询

SQL> alter table test_a parallel;Table altered.Elapsed: 00:00:00.05
SQL> select  count(*) from test_a ;COUNT(*)
----------602704Elapsed: 00:00:00.21Execution Plan
----------------------------------------------------------
Plan hash value: 2663325361--------------------------------------------------------------------------------------------------------
| Id  | Operation              | Name     | Rows  | Cost (%CPU)| Time     |    TQ  |IN-OUT| PQ Distrib |
--------------------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT       |          |     1 |  1290   (1)| 00:00:16 |        |      |            |
|   1 |  SORT AGGREGATE        |          |     1 |            |          |        |      |            |
|   2 |   PX COORDINATOR       |          |       |            |          |        |      |            |
|   3 |    PX SEND QC (RANDOM) | :TQ10000 |     1 |            |          |  Q1,00 | P->S | QC (RAND)  |
|   4 |     SORT AGGREGATE     |          |     1 |            |          |  Q1,00 | PCWP |            |
|   5 |      PX BLOCK ITERATOR |          |   602K|  1290   (1)| 00:00:16 |  Q1,00 | PCWC |            |
|   6 |       TABLE ACCESS FULL| TEST_A   |   602K|  1290   (1)| 00:00:16 |  Q1,00 | PCWP |            |
--------------------------------------------------------------------------------------------------------

通过执行计划,我们来看一下它的执行步骤:

(1)并行服务进程对EMP2表进行全表扫描。

(2)并行服务进程以ITERATOR(迭代)方式访问数据块,也就是并行协调进程分给每个并行服务进程一个数据片,在这个数据片上,并行服务进程顺序地访问每个数据块(Iterator),所有的并行服务进程将扫描的数据块传给另一组并行服务进程(父进程)用于做Hash Group操作。

(3)并行服务父进程对子进程传递过来的数据做Hash Group操作。

(4)并行服务进程(子进程)将处理完的数据发送出去。

(5)并行服务进程(父进程)接收到处理过的数据。

(6)合并处理过的数据,按照随即的顺序发给并行协调进程(QC:Query Conordinator)。

(7)并行协调进程将处理结果发给用户。

当使用了并行执行,SQL的执行计划中就会多出一列:in-out。 该列帮助我们理解数据流的执行方法。 它的一些值的含义如下:

Parallel to Serial(P->S): 表示一个并行操作发送数据给一个串行操作,通常是并行进程将数据发送给并行调度进程。

Parallel to Parallel(P->P):表示一个并行操作向另一个并行操作发送数据,是两个从属进程之间的数据交流。

Parallel Combined with parent(PCWP): 同一个从属进程执行的并行操作,同时父操作也是并行的。

Parallel Combined with Child(PCWC): 同一个从属进程执行的并行操作,子操作也是并行的。

Serial to Parallel ( S->P ) : 一个串行操作发送数据给并行操作,如果select 部分是串行操作,就会出现这个情况。

并行度的设定

(1)在语句中,使用Hint 指定并行度。

(2)使用alter session force parallel 设定并行度。

(3)使用SQL中引用的表或者索引上设定的并行度,原则上Oracle 使用这些对象中并行度最高的那个值作为当前执行的并行度。

示例:

SQL>Select /*+parallel(t 4) */ count(*) from t;

SQL>Alter table t parallel 4;

SQL>Alter session force parallel query parallel 4;

Oracle 默认并行度计算方式:

(1)Oracle 根据CPU的个数,RAC实例的个数以及参数parallel_threads_per_cpu的值,计算出一个并行度。

(2)对于并行访问分区操作,取需要访问的分区数为并行度。

并行度的优先级别从高到低:

Hint->alter session force parallel->表,索引上的设定-> 系统参数

oracle 并行查询相关推荐

  1. oracle并行查询结果不唯一,Oracle并行查询出错

    Oracle并行查询出错 1.错误描述 ORA-12801: 并行查询服务器P007中发出错误信号 ORA-01722:无效数字 12801.00000 -"error signaled i ...

  2. Oracle 并行查询

    所谓并行执行,是指能够将一个大型串行任务(任何DML,一般的DDL)物理的划分为叫多个小的部分,这些较小的部分可以同时得到处理. 何时使用并行执行: 1.必须有一个非常大的任务 2.必须有充足的资源( ...

  3. oracle并行查询结果不唯一,Oracle数据库并行查询出错的解决方法

    Oracle的并行查询是使用多个操作系统级别的Server Process来同时完成一个SQL查询,本文讲解Oracle数据库并行查询出错的解决方法如下: 1.错误描述 sql;"> ...

  4. oracle 实时负载查询,Oracle并行查询

    所谓并行执行,是指能够将一个大型串行任务(任何DML,一般的DDL)物理的划分为叫多个小的部分,这些较小的部分可以同时得到处理 Oracle 并行执行 所谓并行执行,是指能够将一个大型串行任务(任何D ...

  5. oracle 并行参数设置

    oracle parallel 并行执行操作 2009-08-22 17:16:08|  分类: 系统管理技术|举报|字号 订阅 引子:以前一直没太关注oracle并行这个特性.前几天一个兄弟碰到的一 ...

  6. oracle分页查询sql语句通用,oracle分页查询sql语句,oracle分页查询sql语句详解

    oracle分页查询sql语句,oracle分页查询sql语句详解,Oracle分页查询sql语句 Oracle中分页和MySql中的分页不同,MySql中的分页使用关键字limit即可,相对简单一点 ...

  7. oracle 查看并行数据库,Oracle数据库并行查询出错的解决方法

    Oracle的并行查询是使用多个操作系统级别的Server Process来同时完成一个SQL查询,本文讲解Oracle数据库并行查询出错的解决方法如下: 1.错误描述 ORA-12801: 并行查询 ...

  8. Oracle性能误区--MTS,RAC,分区,并行查询

    Oracle性能误区--MTS,RAC,分区,并行查询 学习一项新的东西前需要理解其目的,下面这篇文章侧面介绍了ORACLE中RAC等4个组件的优缺点,以供日后参考.下面为文章全文: 为了提高性能,我 ...

  9. oracle 查询数据库io,理解Oracle中的并行查询IO

    Oracle缓存区如何通过频繁地缓存在共享内存中访问数据来帮助降低磁盘IO瓶颈.Oracle有一种轮换IO机制,叫做"直接路径IO",如果它判断到绕过缓存区直接执行IO会更快速的话 ...

最新文章

  1. (转)---再说卷积
  2. SwiftUI之深入解析如何定制视图的动画和转场
  3. 初学者最常问的几个问题
  4. 虚拟机中Linux安装Tools
  5. 因政府禁令 微软 Windows 9 将作出重大调整
  6. 将list的内容转换成固定个数的分组字符串
  7. Github简单使用 - 更新项目
  8. python3入门基础语法总结_Python基础语法总结(3)
  9. linux firefox 解雇ie,Fire IE
  10. android 视频播放器框架 [饺子播放器](https://github.com/Jzvd/JiaoZiVideoPlayer) 源码解析与评估
  11. 介绍几种常用的Oracle客户端工具
  12. 小刘同学的第一百五十八篇日记
  13. 植物大战僵尸辅助之重叠植物
  14. 欢迎关注个人微信公众账号~
  15. 微信小程序:修改单选radio大小样式
  16. [转][火星帖][留档] 东京秋叶原电器街世风日下
  17. 逍遥模拟器连接不到android,逍遥模拟器不能连上网怎么办?两招解决问题
  18. Ubuntu 1804 升级内核
  19. Ubuntu 设置双网卡,实现内外网同时可用
  20. 创建SDE企业级数据库——在 Oracle 中配置 extproc 以访问 ST_Geometry

热门文章

  1. 球半篮球比分,NBA总决赛第三场:顿凯尔特人VS勇士
  2. def fasterrcnn_resnet50_fpn()实例测试
  3. 医疗器械计算机培训,深度学习,AI医疗器械“学然后知不足”
  4. Delphi中BPL包的使用,个人经验
  5. jersey (RESTful Web Service框架)
  6. 预训练模型-代码补全(一):CodeGeeX(清华大学)
  7. Flink入门篇-编译源码(上)
  8. 解决方案 | 亚洲诚信助力互联网行业网络安全建设
  9. MYSQL查询选修三门以上课程_SQL高级查询的练习题
  10. 《新神榜:杨戬》这样的爆款影视动漫作品,原来都掌握了一个成功密码