oracle insert into select 大数据量_详解Oracle并行模式--概念、机制、并行设置、并行度...

概述

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

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


什么是并行?

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

d9381efb927fc74388d5ebdad6b3d6d0.png

并行的机制

大致结构图如下:

e1d2b298d586032ec15c266baaef21b0.png

下面介绍三种情况

1、scan

333756cad80465636d28db099eaf70e7.png

2、scan+order by

72b359b415bdd7403ff12230ee918764.png

3、scan+group by+ order by

cce80c8b9f13fe18576d9b6a2d260083.png

并行度

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

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

1、对象属性

alter table XX parallel xx;
5999d4fb96406c5363924029989bba53.png

2、hint指定

706aeeb2e3ea8cf8ca5f1299ec89632d.png
3d321a6b01cc8b7ec21f7873a23113f3.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方面内容,感兴趣的朋友可以关注下!

5b789212d18cb21f886ce11e826d0d10.gif
  • 0
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【优质项目推荐】 1、项目代码均经过严格本地测试,运行OK,确保功能稳定后才上传平台。可放心下载并立即投入使用,若遇到任何使用问题,随时欢迎私信反馈与沟通,博主会第一时间回复。 2、项目适用于计算机相关专业(如计科、信息安全、数据科学、人工智能、通信、物联网、自动化、电子信息等)的在校学生、专业教师,或企业员工,小白入门等都适用。 3、该项目不仅具有很高的学习借鉴价值,对于初学者来说,也是入门进阶的绝佳选择;当然也可以直接用于 毕设、课设、期末大作业或项目初期立项演示等。 3、开放创新:如果您有一定基础,且热爱探索钻研,可以在此代码基础上二次开发,进行修改、扩展,创造出属于自己的独特应用。 欢迎下载使用优质资源!欢迎借鉴使用,并欢迎学习交流,共同探索编程的无穷魅力! 基于业务逻辑生成特征变python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变python实现源码+数据集+超详细注释.zip 基于业务逻辑生成特征变python实现源码+数据集+超详细注释.zip 基于业务逻辑生成特征变python实现源码+数据集+超详细注释.zip
oracle_vm_virtualbox_extension_pack-6.1.30.vbox-extpack是Oracle VirtualBox虚拟机软件的扩展包。VirtualBox是一款开源的虚拟化软件,能够在主机操作系统上创建和运行多个虚拟机。这个扩展包提供了额外的功能和特性,以增强VirtualBox的功能。 使用oracle_vm_virtualbox_extension_pack-6.1.30.vbox-extpack,可以让VirtualBox支持更多的功能。这个扩展包包含了一系列的驱动程序和工具,用于改善虚拟机的性能和兼容性。例如,它可以提供对USB设备的支持,让虚拟机可以识别和使用连接到主机上的USB设备。此外,扩展包还可以提供对虚拟磁盘映像的加密功能,保护虚拟机中的数据安全。 安装并启用扩展包非常简单。只需双击oracle_vm_virtualbox_extension_pack-6.1.30.vbox-extpack文件,VirtualBox会自动检测并提示您安装扩展包。然后,按照安装向导的指示进行操作即可完成安装过程。 安装扩展包后,您可以在VirtualBox的设置中找到新的功能选项。这些选项可以用于配置USB设备支持、加密虚拟磁盘、设置虚拟机的网络功能等等。通过配置这些选项,您可以更好地满足您的虚拟化需求,提高虚拟机的使用体验。 总之,oracle_vm_virtualbox_extension_pack-6.1.30.vbox-extpack是VirtualBox的扩展包,可以为用户提供额外的功能和特性。它的安装简单方便,能够帮助用户更好地利用VirtualBox进行虚拟化操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值