oracle select机制_想知道Oracle并行机制?看完这篇就懂了

本文详细介绍了Oracle的并行机制,包括并行的概念、并行度的设定方式以及在DML和DDL操作中的应用。通过并行处理,可以提高大数据量操作的效率,但需要注意并行度的合理设置,避免过度消耗资源。
摘要由CSDN通过智能技术生成

概述

并行是Oracle为了提高大数据量的运算效率而提供多进程协作技术,它可以让多个CPU同时处理一个计算任务,充分使用系统资源,提高计算效率。

不过并行我用的比较少,一般是在优化sql没办法的时候才做的一步,因为需要消耗到CPU等资源,而且比较充足的情况下才考虑。


什么是并行?

将一件工作分成很多块,分别由不同的进程来执行,最后将结果合并。大部分的DML(insert/update/delete/merge)、DDL、Query都支持并行操作。

7b7ec2af7a6dbdce06690879faefd710.png

并行的机制

大致结构图如下:

4a8214e6a0af6289ba15445873183f78.png

下面介绍三种情况

1、scan

b92395d7017447d7497a4a85c58e0032.png

2、scan+order by

99f071ef8c81187442aa855054cc8eca.png

3、scan+group by+ order by

85aaf30a5a53b3088147aafe3adc0d41.png

并行度

所谓并行度,就是Oracle在进行并行处理时,会启动几个并行进程来同时执行。

下面介绍下并行度的设定方式。

1、对象属性

alter table XX parallel xx;
b3222adec8df493376199fdfced6cca2.png

2、hint指定

82acbaab5b996990d3a3be0c8c6eda23.png
33ffa935246eb5f030aad37f4f0210b7.png

对于insert ……select ……如何设置并行

insert……select….包含两个部分,query和dml,可以为这两个部分分别设置并行度。因为insert操作是dml,因此还需要通过alter session方式把pdml启用,如:

alter session enable parallel dml;

insert /*+ append parallel(a,4) */ into table_a a

select /*+ parallel(b,8) */ * from table_b b where ……;


既有DML又有query的SQL如何设置并行度?如insert …..select…..

1) 如果写入量大,则在insert上加并行会明显提升性能;否则在insert上加并行基本没有什么意义。如:

insert into t(game_name,num) select game_name,count(1) cnt from popt_total_login_all_his group by game_name;

这种SQL主要瓶颈在查询上,写入量很少,因此只需要在查询部分设置并行即可。

2) 如果查询量大,则在查询上加并行会明显提升性能;

3) 如果写入和查询量都大,则在两个部分都要加并行,不要让其中一方成为瓶颈。

总结起来就是:瓶颈在部分,就在这部分上加并行;如果都有瓶颈,则都加并行。


对于pdml,建议:

1) 由于并行dml有诸多限制和弊端,因此在写入量不大的情况下,尽量不启用并行dml。

2) insert和query的并行度不一定要一致,可根据实际调整,一般设置query并行度大于等于insert并行度。并行度最好设置为2的n次方。

3) 并行度不要设置超过CPU的个数


一般来说,并行度越大SQL的执行效率越高,但是不建议设置超过CPU核数的并行度。在当前的RAC中,考虑到同时会有多个任务在跑,为了不影响其他任务,并行度需要严格控制在32个以下,一般的建议值是8和16。另外,建议并行度设置为2的n次方,如2/4/8/16/32等。

后面会分享更多DBA方面内容,感兴趣的朋友可以关注下!

eab9cd18f4f404ba8b2e0da199a63c49.gif
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值