阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Oracle开启并行的几种方法

566次阅读
没有评论

共计 8347 个字符,预计需要花费 21 分钟才能阅读完成。

并行执行是同时开启多个进程 / 线程来完成同一个任务,并行执行的每一个进程 / 线程都会消耗额外的硬件资源,所以并行执行的本质就是以额外的硬件资源消耗来换取执行时间的缩短。这里的额外硬件资源消耗是指对数据库服务器上多个 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 |        |
————————————————————————————————————–
…..

从上面的执行计划中可以看出,走的是对表 EMP 的全表扫描,PX… 表示的就是走的并行

默认并行度的算法如下:

默认并行度 =parallel_threads_per_cpu*cpu_count

如果想对表开启 8 个并行度则执行:alter table emp parallel 8;

scott@TEST>select table_name,degree from user_tables where table_name=’EMP’;
 
TABLE_NAME            DEGREE
—————————— ———-
EMP              DEFAULT
 
scott@TEST>alter table emp parallel 8;
 
Table altered.
 
scott@TEST>select table_name,degree from user_tables where table_name=’EMP’;
 
TABLE_NAME            DEGREE
—————————— ———-
EMP                8

2、使用并行 Hint

有如下一些并行 Hint 可以用来控制是否启用并行及指定并行度

1) /*+ parallel(table[,degree]) */  #用于指定并行度去访问指定表,如果没有指定并行度 degree,则使用 Oracle 默认并行度

2) /*+ noparallel(table) */  #对指定表不使用并行访问

3) /*+ parallel_index(table[,index[,degree]]) */  #对指定的分区索引以指定的并行度去做并行范围扫描

4) /*+ no_parallel_index(table[,index]) */  #对指定的分区索不使用并行访问

5) /*+ pq_distribute(table,out,in) */ #对指定表以 out/in 所指定的方式来传递数据,这里 out/in 的值可以是 HASH/NONE/BROADCAST/PARTITION 中的任意一种如 /*+ pq_distribute(table,none,partition) */

把表 EMP 修改回并行度为 1

scott@TEST>alter table emp noparallel;
 
Table altered.
 
scott@TEST>select table_name,degree from user_tables where table_name=’EMP’;
 
TABLE_NAME            DEGREE
—————————— ———-
EMP                1

使用并行 Hint 执行上之前的 SQL

scott@TEST>select /*+ parallel(emp) */* 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 |        |
————————————————————————————————————–

从上面的执行计划中可以看出,走的是并行

3、使用 alter session 命令

使用 alter session 命令,可以在当前 session 中强制启用并行查询或并行 DML。如果强制启用了并行查询或者并行 DML,那就意味着从执行 alter session 命令强制开启并行的那个时间点开始,在这个 session 中随后执行的所有 SQL 都将以并行的方式执行,有如下四种方法在当前 session 中强制开启并行

1) alter session parallel query

在当前 session 中强制开启并行查询,没有指定并行度,Oracle 使用默认并行度

2) alter session parallel query  parallel n

在当前 session 中强制开启并行查询,并且指定并行度为 n

3) alter session parallel dml

在当前 session 中强制开启并行 DML, 没有指定并行度,Oracle 使用默认并行度

4) alter session parallel dml  parallel n

在当前 session 中强制开启并行 DML,并且指定并行度为 n

表 EMP 并行度仍为 1,在 session 中强制开启并行:

scott@TEST>select table_name,degree from user_tables where table_name=’EMP’;
 
TABLE_NAME            DEGREE
—————————— ———-
EMP                1
 
scott@TEST>set autotrace traceonly
scott@TEST>alter session force parallel query;
 
Session altered.
 
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 |        |
————————————————————————————————————–
……

从执行计划中可以看出走的是并行。

取消当前 session 并行使用如下语句 alter session disable parallel query;

scott@TEST>alter session disable parallel query;
 
Session altered.
 
scott@TEST>select * from emp;
 
14 rows selected.
 
 
Execution Plan
———————————————————-
Plan hash value: 3956160932
 
————————————————————————–
| Id  | Operation    | Name | Rows  | Bytes | Cost (%CPU)| Time    |
————————————————————————–
|  0 | SELECT STATEMENT  |  |    14 |  1218 |    3  (0)| 00:00:01 |
|  1 |  TABLE ACCESS FULL| EMP  |    14 |  1218 |    3  (0)| 00:00:01 |
————————————————————————–
……

4、11gR2 的自动并行

Oracle 在 11gR2 中引入了自动并行 (Auto DOP),自动并行的开启受参数 parallel_degree_policy 的控制,其默认值为 MANUAL,即自动并行在默认情况下并没有开启。如果通过更改 PARALLEL_DEGREE_POLICY 的值而开启了自动并行,那么后面执行的 SQL 的执行方式是串行还是并行,以及并行执行的并行度是多少等,就都是由 Oracle 自动来决定了。

scott@TEST>select table_name,degree from user_tables where table_name in (‘EMP’,’EMP_TEMP’);
 
TABLE_NAME                                        DEGREE
—————————————————————————————— ————————————————————
EMP                                                1
EMP_TEMP                                                1
 
scott@TEST>alter session set parallel_degree_policy=AUTO;
 
Session altered.
 
scott@TEST>set autotrace traceonly
scott@TEST>select * from emp;
 
14 rows selected.
 
 
Execution Plan
———————————————————-
Plan hash value: 3956160932
 
————————————————————————–
| Id  | Operation    | Name | Rows  | Bytes | Cost (%CPU)| Time    |
————————————————————————–
|  0 | SELECT STATEMENT  |  |    14 |  1218 |    3  (0)| 00:00:01 |
|  1 |  TABLE ACCESS FULL| EMP  |    14 |  1218 |    3  (0)| 00:00:01 |
————————————————————————–
……
scott@TEST>select * from emp_temp;
 
1835008 rows selected.
 
 
Execution Plan
———————————————————-
Plan hash value: 2661083444
 
————————————————————————————————————–
| Id  | Operation        | Name  | Rows | Bytes | Cost (%CPU)| Time    |    TQ  |IN-OUT| PQ Distrib |
————————————————————————————————————–
|  0 | SELECT STATEMENT    |      |  1835K|    66M|  1683  (1)| 00:00:21 |  | |        |
|  1 |  PX COORDINATOR      |    |  |  |        |    |    | |        |
|  2 |  PX SEND QC (RANDOM)| :TQ10000 |  1835K|    66M|  1683  (1)| 00:00:21 |  Q1,00 | P->S | QC (RAND)  |
|  3 |    PX BLOCK ITERATOR |      |  1835K|    66M|  1683  (1)| 00:00:21 |  Q1,00 | PCWC |      |
|  4 |    TABLE ACCESS FULL| EMP_TEMP |  1835K|    66M|  1683  (1)| 00:00:21 |  Q1,00 | PCWP |        |
————————————————————————————————————–
……

从上面的输出可以看出表 EMP 和 EMP_TEMP 的并行度都为 1,但是两个表的数据量相关很大,EMP 只有 14 条数据,EMP_TEMP 有 1835008 条数据。在执行时 Oracle 选择的执行方式就有不同,EMP 是串行执行,而 EMP_TEMP 为并行执行。

参考《基于 Oracle 的 SQL 优化》http://www.linuxidc.com/Linux/2017-02/140521.htm

官方文档:http://docs.oracle.com/cd/E11882_01/server.112/e41084/statements_2013.htm#i2231814

更多 Oracle 相关信息见 Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12

本文永久更新链接地址 :http://www.linuxidc.com/Linux/2017-03/141965.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计8347字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19348
评论数
4
阅读量
7805155
文章搜索
热门文章
开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南 大家好,我是星哥。之前介绍了腾讯云的 Code...
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板 1Panel:小白轻松构建 Web 服务与面板加固指南 哈喽,我是星哥,经常有人问我不...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
开源MoneyPrinterTurbo 利用AI大模型,一键生成高清短视频!

开源MoneyPrinterTurbo 利用AI大模型,一键生成高清短视频!

  开源 MoneyPrinterTurbo 利用 AI 大模型,一键生成高清短视频! 在短视频内容...
150元打造低成本NAS小钢炮,捡一块3865U工控板

150元打造低成本NAS小钢炮,捡一块3865U工控板

150 元打造低成本 NAS 小钢炮,捡一块 3865U 工控板 一块二手的熊猫 B3 工控板 3865U,搭...
免费领取huggingface的2核16G云服务器,超简单教程

免费领取huggingface的2核16G云服务器,超简单教程

免费领取 huggingface 的 2 核 16G 云服务器,超简单教程 前言 HuggingFace.co...
优雅、强大、轻量开源的多服务器监控神器

优雅、强大、轻量开源的多服务器监控神器

优雅、强大、轻量开源的多服务器监控神器 在多台服务器同时运行的环境中,性能监控、状态告警、资源可视化 是运维人...
颠覆 AI 开发效率!开源工具一站式管控 30+大模型ApiKey,秘钥付费+负载均衡全搞定

颠覆 AI 开发效率!开源工具一站式管控 30+大模型ApiKey,秘钥付费+负载均衡全搞定

  颠覆 AI 开发效率!开源工具一站式管控 30+ 大模型 ApiKey,秘钥付费 + 负载均衡全...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
每天一个好玩的网站-手机博物馆-CHAZ 3D Experience

每天一个好玩的网站-手机博物馆-CHAZ 3D Experience

每天一个好玩的网站 - 手机博物馆 -CHAZ 3D Experience 一句话介绍:一个用 3D 方式重温...
让微信公众号成为 AI 智能体:从内容沉淀到智能问答的一次升级

让微信公众号成为 AI 智能体:从内容沉淀到智能问答的一次升级

让微信公众号成为 AI 智能体:从内容沉淀到智能问答的一次升级 大家好,我是星哥,之前写了一篇文章 自己手撸一...
星哥带你玩飞牛 NAS-9:全能网盘搜索工具 13 种云盘一键搞定!

星哥带你玩飞牛 NAS-9:全能网盘搜索工具 13 种云盘一键搞定!

星哥带你玩飞牛 NAS-9:全能网盘搜索工具 13 种云盘一键搞定! 前言 作为 NAS 玩家,你是否总被这些...
星哥带你玩飞牛NAS-11:咪咕视频订阅部署全攻略

星哥带你玩飞牛NAS-11:咪咕视频订阅部署全攻略

星哥带你玩飞牛 NAS-11:咪咕视频订阅部署全攻略 前言 在家庭影音系统里,NAS 不仅是存储中心,更是内容...
150元打造低成本NAS小钢炮,捡一块3865U工控板

150元打造低成本NAS小钢炮,捡一块3865U工控板

150 元打造低成本 NAS 小钢炮,捡一块 3865U 工控板 一块二手的熊猫 B3 工控板 3865U,搭...