首頁 資料庫 mysql教程 Oracle 11g 并行DML

Oracle 11g 并行DML

Jun 07, 2016 pm 05:31 PM
數據

并行DML应用在决策支撑系统(decision support system DSS)环境时,对于访问大对象时,可扩展性和性能有灰常显著的效果。不能把

Oracle 11g 并行DML(PDML)

并行DML应用在决策支撑系统(decision support system  DSS)环境时,对于访问大对象时,可扩展性和性能有灰常显著的效果。

不能把PDML当成提高OLTP应用速度的一个特性。PDML在大型数据仓库中很有用,它利于大量的数据批量更新。

开启PDML

PDML有别于并行查询,除非显示的请求PDML ,否则不能执行PDML。

SQL> alter session enable parallel dml;

Session altered.

这个表属性可能是并行的,但是与并行查询不同,这对于PDML还不够,必须显示的在会话中启动PDML.

PDML 采用的是一种伪分布式的实现,存在一些限制

1、PDML期间不支持触发器

2、PDML期间,不支持某些方式声明的引用完整性。因为表中的每个部分会在单独的会话中作为单独的事务进行处理。PDML操作不支持自引用完整性,那样可能会出现死锁

3、提交或回滚之前,不能访问用PDML修改的表。

4、不支持延迟约束

5、如果表示分区的,PDML只可能有位图索引或LOB列的表上执行。而且并行度取决于分区数。无法在子分区内再并行操作,因为每一个分区只有一个并行执行服务器来处理

6、执行PDML时,不支持分布式事务

7、PDML不支持聚簇表

测试:

SQL> alter session disable parallel dml;


SQL> explain plan for update /*+ PARALLEL(4) */ test_b set object_name='AAAA';

SQL> select * from table(dbms_xplan.display);


Plan hash value: 725367477
---------------------------------------------------------------------------------------------------------------
| Id  | Operation            | Name    | Rows  | Bytes | Cost (%CPU)| Time    |    TQ  |IN-OUT| PQ Distrib |
---------------------------------------------------------------------------------------------------------------
|  0 | UPDATE STATEMENT      |          | 75339 |  1839K|    81  (0)| 00:00:01 |        |      |            |
|  1 |  UPDATE              | TEST_B  |      |      |            |          |        |      |            |
|  2 |  PX COORDINATOR      |          |      |      |            |          |        |      |            |
|  3 |    PX SEND QC (RANDOM)| :TQ10000 | 75339 |  1839K|    81  (0)| 00:00:01 |  Q1,00 | P->S | QC (RAND)  |
|  4 |    PX BLOCK ITERATOR |          | 75339 |  1839K|    81  (0)| 00:00:01 |  Q1,00 | PCWC |            |
|  5 |      TABLE ACCESS FULL| TEST_B  | 75339 |  1839K|    81  (0)| 00:00:01 |  Q1,00 | PCWP |            |
---------------------------------------------------------------------------------------------------------------------------------------

--发现并没有真正的实现并行.

开启PDML

SQL> alter session enable parallel dml;

Session altered.

SQL> explain plan for update /*+ parallel(4) */ test_b set object_name='BBBBB';

Explained.

SQL> select * from table(dbms_xplan.display);

Plan hash value: 2467161980

------------------------------------------------------------------------------------------------------------------
| Id  | Operation                | Name    | Rows  | Bytes | Cost (%CPU)| Time    |    TQ  |IN-OUT| PQ Distrib |
------------------------------------------------------------------------------------------------------------------
|  0 | UPDATE STATEMENT        |          | 75339 |  1839K|    81  (0)| 00:00:01 |        |      |            |
|  1 |  PX COORDINATOR          |          |      |      |            |          |        |      |            |
|  2 |  PX SEND QC (RANDOM)    | :TQ10001 | 75339 |  1839K|    81  (0)| 00:00:01 |  Q1,01 | P->S | QC (RAND)  |
|  3 |    INDEX MAINTENANCE    | TEST_B  |      |      |            |          |  Q1,01 | PCWP |            |
|  4 |    PX RECEIVE          |          | 75339 |  1839K|    81  (0)| 00:00:01 |  Q1,01 | PCWP |            |
|  5 |      PX SEND RANGE      | :TQ10000 | 75339 |  1839K|    81  (0)| 00:00:01 |  Q1,00 | P->P | RANGE      |
|  6 |      UPDATE            | TEST_B  |      |      |            |          |  Q1,00 | PCWP |            |
|  7 |        PX BLOCK ITERATOR |          | 75339 |  1839K|    81  (0)| 00:00:01 |  Q1,00 | PCWC |            |
|  8 |        TABLE ACCESS FULL| TEST_B  | 75339 |  1839K|    81  (0)| 00:00:01 |  Q1,00 | PCWP |            |
------------------------------------------------------------------------------------------------------------------

---------------------------------------------------------------------------------------------------------------------------------------

注:在并发INSERT的时候,数据是被使用APPEND方式插入到表中,如果需要常规方式插入,需要加上noappend提示.

总结:

PDML需要显示打开,只有打开了PDML ,, 才能是真正意义上的并发操作.

SQL> alter session enable parallel dml;

执行完可以关闭

SQL> alter session disable parallel dml;

相关阅读:

Oracle DML流程

PL/SQL“ ORA-14551: 无法在查询中执行 DML 操作”解决

MySQL常用DDL、DML、DCL语言整理(附样例)

Oracle基本事务和ForAll执行批量DML练习

Oracle DML语句(insert,update,delete) 回滚开销估算

linux

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

使用ddrescue在Linux上恢復數據 使用ddrescue在Linux上恢復數據 Mar 20, 2024 pm 01:37 PM

使用ddrescue在Linux上恢復數據

開源!超越ZoeDepth! DepthFM:快速且精確的單目深度估計! 開源!超越ZoeDepth! DepthFM:快速且精確的單目深度估計! Apr 03, 2024 pm 12:04 PM

開源!超越ZoeDepth! DepthFM:快速且精確的單目深度估計!

如何多條件使用Excel過濾功能 如何多條件使用Excel過濾功能 Feb 26, 2024 am 10:19 AM

如何多條件使用Excel過濾功能

超級智能體生命力覺醒!可自我更新的AI來了,媽媽再也不用擔心資料瓶頸難題 超級智能體生命力覺醒!可自我更新的AI來了,媽媽再也不用擔心資料瓶頸難題 Apr 29, 2024 pm 06:55 PM

超級智能體生命力覺醒!可自我更新的AI來了,媽媽再也不用擔心資料瓶頸難題

Google狂喜:JAX性能超越Pytorch、TensorFlow!或成GPU推理訓練最快選擇 Google狂喜:JAX性能超越Pytorch、TensorFlow!或成GPU推理訓練最快選擇 Apr 01, 2024 pm 07:46 PM

Google狂喜:JAX性能超越Pytorch、TensorFlow!或成GPU推理訓練最快選擇

iPhone上的蜂窩數據網路速度慢:修復 iPhone上的蜂窩數據網路速度慢:修復 May 03, 2024 pm 09:01 PM

iPhone上的蜂窩數據網路速度慢:修復

美國空軍高調展示首個AI戰鬥機!部長親自試駕全程未乾預,10萬行代碼試飛21次 美國空軍高調展示首個AI戰鬥機!部長親自試駕全程未乾預,10萬行代碼試飛21次 May 07, 2024 pm 05:00 PM

美國空軍高調展示首個AI戰鬥機!部長親自試駕全程未乾預,10萬行代碼試飛21次

首個自主完成人類任務機器人出現,五指靈活速度超人,大模型加持虛擬空間訓練 首個自主完成人類任務機器人出現,五指靈活速度超人,大模型加持虛擬空間訓練 Mar 11, 2024 pm 12:10 PM

首個自主完成人類任務機器人出現,五指靈活速度超人,大模型加持虛擬空間訓練

See all articles