如何加速Oracle大批量数据处理

<p style="text-align: center;"><strong><span style="">如何加速</span>
<span style="font-size: 16pt; font-family: 'Times New Roman';" lang="EN-US">Oracle</span>
<span style="">大批量数据处理</span>
</strong>
</p>
<p><strong><span style="">
<p class="MsoNormal" style=""><strong><span style="font-size: 12pt;" lang="EN-US"><span><span style="font-family: Times New Roman;">一、<span style='font-family: "Times New Roman"; font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal;'> </span>
</span>
</span>
</span>
</strong>
<strong><span style="">提高</span>
</strong>
<strong><span style="font-size: 12pt;" lang="EN-US"><span style="font-family: Times New Roman;">DML</span>
</span>
</strong>
<strong><span style="">操作的办法:</span>
</strong>
<strong></strong>
</p>
<p><strong><span style="font-size: 10.5pt;">简单说来:<span lang="EN-US"><br></span>
1、暂停索引,更新后恢复<span lang="EN-US">.</span>
避免在更新的过程中涉及到索引的重建<span lang="EN-US">.<br></span>
2、批量更新,每更新一些记录后及时进行提交动作<span lang="EN-US">.</span>
避免大量占用回滚段和或临时表空间<span lang="EN-US">.<br></span>
3、创建一临时的大的表空间用来应对这些更新动作.</span>
</strong>
</p>
<p><strong><span style="font-size: 10.5pt;" lang="EN-US">4</span>
</strong>
<strong><span style="font-size: 10.5pt;">、批量更新,每更新一些记录后及时进行提交动作<span lang="EN-US">.</span>
避免大量占用回滚段和或临时表空间<span lang="EN-US">.</span>
</span>
</strong>
</p>
<p><strong><span style="font-size: 10.5pt;" lang="EN-US">5</span>
</strong>
<strong><span style="font-size: 10.5pt;">、创建一临时的大的表空间用来应对这些更新动作.</span>
</strong>
</p>
<p><strong><span style="font-size: 10.5pt;" lang="EN-US">6</span>
</strong>
<strong><span style="font-size: 10.5pt;">、加大排序缓冲区<span lang="EN-US"><br>
alter session set sort_area_size=100000000;<br>
insert <span class="hilite2">into</span>
tableb select * from tablea;<br>
commit;</span>
</span>
</strong>
</p>
<p style="text-indent: 21.1pt;"><strong><span style="font-size: 10.5pt;">如果<span lang="EN-US">UPDATE</span>
的是索引字段,就会涉及到索引的重建,暂停索引不会提高多少的速度,反而有可能降低<span lang="EN-US">UPDATE</span>
速度,<span lang="EN-US"><br></span>
因为在更新是索引可以提高数据的查询速度,重建索引引起的速度降低影响不大。</span>
</strong>
</p>
<p><strong><span style="font-size: 10.5pt;" lang="EN-US">ORACLE</span>
</strong>
<strong><span style="font-size: 10.5pt;">优化修改参数最多也只能把性能提高<span lang="EN-US">15%</span>
,大部分都是</span>
</strong>
<strong><span style="text-decoration: underline;"><span style="" lang="EN-US">SQL</span>
</span>
</strong>
<strong><span style="font-size: 10.5pt;">语句的优化!</span>
</strong>
</p>
<p style=""><strong><span style="font-size: 10.5pt;" lang="EN-US">update</span>
</strong>
<strong><span style="font-size: 10.5pt;">总体来说比<span lang="EN-US">insert</span>
要慢<span lang="EN-US"></span>
:<span lang="EN-US"><br></span>
几点建议:<span lang="EN-US"><br>
1</span>
、如果更新的数据量接近整个表,就不应该使用<span lang="EN-US">index</span>
而应该采用全表扫描<span lang="EN-US"><br>
2</span>
、减少不必要的<span lang="EN-US">index</span>
,因为<span lang="EN-US">update</span>
表通常需要<span lang="EN-US">update index<br>
3</span>
、如果你的服务器有多个<span lang="EN-US">cpu</span>
,采用<span lang="EN-US">parellel hint</span>
,可以大幅度的提高效率<span lang="EN-US"><br></span>
另外,建表的参数非常重要,对于更新非常频繁的表,建议加大<span lang="EN-US">PCTFREE</span>
的值,以保证数据块中有足够的空间用于<span lang="EN-US">UPDATE</span>
, 从而降低<span lang="EN-US">CHAINED_ROWS</span>
。<span lang="EN-US"></span>
</span>
</strong>
</p>
<p class="MsoNormal" style=""><strong><span style="font-size: 14pt;" lang="EN-US"><span><span style="font-family: Times New Roman;">二、<span style='font-family: "Times New Roman"; font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal;'> </span>
</span>
</span>
</span>
</strong>
<span>各种批量<span style="font-family: Times New Roman;">DML</span>
操作:</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt 24pt;"><span style="font-size: small;"><span>(<span style="font-family: Times New Roman;">1</span>
)、<span style="font-family: Times New Roman;">oracle</span>
批量拷贝:</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt 24pt; text-indent: 24pt;"><span lang="EN-US"><span style="font-size: small; font-family: Times New Roman;">set arraysize 20<br>
set copycommit 5000<br>
copy from </span>
<a href="mailto:username/password@oracle_name"><span style="font-size: small; font-family: Times New Roman;">username/password@oraclename</span>
</a>
<span style="font-size: small;"><span style="font-family: Times New Roman;"> append table_name1<br>
using select * from table_name2;</span>
</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt;"><span style="font-size: small;"><span><span><span style="font-family: Times New Roman;"> </span>
</span>
(<span style="font-family: Times New Roman;">2</span>
)、常规插入方式:</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt;"><span style="font-size: small;"><span><span><span style="font-family: Times New Roman;"> </span>
</span>
insert into t1 select * from t;</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt;"><span style="font-size: small;"><span><span> </span>
为了提高速度可以使用下面方法,来减少插入过程中产生的日志:</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt;"><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US"><span style="font-size: small;"><span> </span>
alter table t1 nologging;</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt; text-indent: 63.25pt;"><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US"><span style="font-size: small;">insert into t1 select * from t;</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt; text-indent: 63.25pt;"><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US"><span style="font-size: small;">commit;</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt;"><span style="font-size: small;"><span><span> </span>
(3)、CTAS方式:</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt;"><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US"><span style="font-size: small;"><span> </span>
<span></span>
create table t1</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt 63pt;"><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US"><span style="font-size: small;">as<br>
select * from t;</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt 63pt;"><span style="font-size: small;"><span>为了提高速度可以使用下面方法,来减少插入过程中产生的日志,并且可以制定并行度: </span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt; text-indent: 51.45pt;"><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US"><span style="font-size: small;">create table t1 nologging parallel(degree 2) as select * from t;</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt;"><span style="font-size: small;"><span><span> </span>
(4)、Direct-Path插入:</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt;"><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US"><span style="font-size: small;"><span> </span>
insert /*+append*/ into t1 select * from t;</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt;"><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US"><span style="font-size: small;"><span> </span>
commit;</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt;"><span style="font-size: small;"><span><span> </span>
为了提高速度可以使用下面方法,来减少插入过程中产生的日志:</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt;"><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US"><span style="font-size: small;"><span> </span>
alter table t1 nologging;</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt;"><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US"><span style="font-size: small;"><span> </span>
insert /*+append*/ into t1 select * from t;</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt;"><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US"><span style="font-size: small;"></span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt;"><span><span style="font-size: small;"><span> </span>
Direct-Path插入特点:</span>
</span>
</p>
<p class="MsoNormal" style=""><strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US"><span><span style="font-size: small;">1、</span>
<span style='font-family: "Times New Roman"; font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal;'> </span>
</span>
</span>
</strong>
<span style="font-size: small;"><strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">append</span>
</strong>
<strong><span style="">只在</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">insert … select …</span>
</strong>
<strong><span style="">中起作用,像</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">insert /*+ append */ into t values(…)</span>
</strong>
<strong><span style="">这类的语句是不起作用的。在</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">update</span>
</strong>
<strong><span style="">、</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">delete</span>
</strong>
<strong><span style="">操作中,</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">append</span>
</strong>
<strong><span style="">也不起作用。</span>
</strong>
<strong></strong>
</span>
</p>
<p class="MsoNormal" style=""><strong><span lang="EN-US"><span><span style="font-family: Times New Roman;"><span style="font-size: small;">2、</span>
<span style='font-family: "Times New Roman"; font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal;'> </span>
</span>
</span>
</span>
</strong>
<span style="font-size: small;"><strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">Direct-Path</span>
</strong>
<strong><span style="">会使数据库不记录直接路径导入的数据的重做日志,会对恢复带来麻烦。</span>
</strong>
<strong></strong>
</span>
</p>
<p class="MsoNormal" style=""><strong><span lang="EN-US"><span><span style="font-family: Times New Roman;"><span style="font-size: small;">3、</span>
<span style='font-family: "Times New Roman"; font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal;'> </span>
</span>
</span>
</span>
</strong>
<span style="font-size: small;"><strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">Direct-Path</span>
</strong>
<strong><span style="">直接在表段的高水位线以上的空白数据块中写数据,不会重用高水位线以下的空间,会对空间的使用造成一定的浪费,对查询的性能也会造成一定的影响。而常规插入会优先考虑使用高水位线之下有空闲空间存在的数据块。因此理论上</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">Direct-Path</span>
</strong>
<strong><span style="">插入会比常规插入速度更快,因为</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">Direct-Path</span>
</strong>
<strong><span style="">直接使用新数据块,而常规插入要遍历</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">freelist</span>
</strong>
<strong><span style="">获取可用空闲数据块,如果</span>
</strong>
<strong><span style="">同</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US"> nologging </span>
</strong>
<strong><span style="">配合,这种速度优势会更加明显。</span>
</strong>
<strong></strong>
</span>
</p>
<p class="MsoNormal" style=""><strong><span lang="EN-US"><span><span style="font-family: Times New Roman;"><span style="font-size: small;">4、</span>
<span style='font-family: "Times New Roman"; font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal;'> </span>
</span>
</span>
</span>
</strong>
<span style="font-size: small;"><strong><span style="">以</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">append</span>
</strong>
<strong><span style="">方式插入记录后,要执行</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">commit</span>
</strong>
<strong><span style="">,才能对表进行查询。否则会出现错误:</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">ORA-12838: </span>
</strong>
<strong><span style="">无法在并行模式下修改之后读</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">/</span>
</strong>
<strong><span style="">修改对象。</span>
</strong>
<strong></strong>
</span>
</p>
<p class="MsoNormal" style=""><strong><span lang="EN-US"><span><span style="font-family: Times New Roman;"><span style="font-size: small;">5、</span>
<span style='font-family: "Times New Roman"; font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal;'> </span>
</span>
</span>
</span>
</strong>
<span style="font-size: small;"><strong><span style="">用</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">append</span>
</strong>
<strong><span style="">导入数据后,如果没有提交或者回滚,在其他会话中任何对该表的</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">DML</span>
</strong>
<strong><span style="">都会被阻塞(不会报错),但对该表的查询可以正常执行。</span>
</strong>
<strong></strong>
</span>
</p>
<p class="MsoNormal" style=""><strong><span lang="EN-US"><span><span style="font-family: Times New Roman;"><span style="font-size: small;">6、</span>
<span style='font-family: "Times New Roman"; font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal;'> </span>
</span>
</span>
</span>
</strong>
<span style="font-size: small;"><strong><span style="">在归档模式下,要把表设置为</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">nologging</span>
</strong>
<strong><span style="">,然后以</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">append</span>
</strong>
<strong><span style="">方式批量添加记录,才会显著减少</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">redo</span>
</strong>
<strong><span style="">数量。在非归档模式下,不必设置表的</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US"> nologging</span>
</strong>
<strong><span style="">属性,即可减少</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">redo</span>
</strong>
<strong><span style="">数量。如果表上有索引,则</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">append</span>
</strong>
<strong><span style="">方式批量添加记录,不会减少索引上产生的</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">redo</span>
</strong>
<strong><span style="">数量,索引上的</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">redo </span>
</strong>
<strong><span style="">数量可能比表的</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">redo</span>
</strong>
<strong><span style="">数量还要大。</span>
</strong>
<strong></strong>
</span>
</p>
<p class="MsoNormal" style=""><strong><span lang="EN-US"><span><span style="font-family: Times New Roman;"><span style="font-size: small;">7、</span>
<span style='font-family: "Times New Roman"; font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal;'> </span>
</span>
</span>
</span>
</strong>
<span style="font-size: small;"><strong><span style="">数据直接插入数据文件,绕过</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">buffer cache</span>
</strong>
<strong><span style="">并且忽略了引用完整性约束。</span>
</strong>
<strong></strong>
</span>
</p>
<p class="MsoNormal" style=""><strong><span lang="EN-US"><span><span style="font-family: Times New Roman;"><span style="font-size: small;">8、</span>
<span style='font-family: "Times New Roman"; font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal;'> </span>
</span>
</span>
</span>
</strong>
<span style="font-size: small;"><strong><span style="">不管表是否在</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">nologging </span>
</strong>
<strong><span style="">下,只要是</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US"> directinsert</span>
</strong>
<strong><span style="">,就不会对数据内容生成</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">undo</span>
</strong>
<strong><span style="">。</span>
</strong>
<strong></strong>
</span>
</p>
<p class="MsoNormal" style=""><strong><span lang="EN-US"><span><span style="font-family: Times New Roman;"><span style="font-size: small;">9、</span>
<span style='font-family: "Times New Roman"; font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal;'> </span>
</span>
</span>
</span>
</strong>
<span style="font-size: small;"><strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">Oracle</span>
</strong>
<strong><span style="">在</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">Direct-Path INSERT </span>
</strong>
<strong><span style="">操作末尾,对具有索引的表执行索引维护,这样就避免了在</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">drop</span>
</strong>
<strong><span style="">掉索引后,再</span>
</strong>
<strong><span style="color: #4b4b4b; font-family: Verdana;" lang="EN-US">rebuild</span>
</strong>
<strong><span style="">。</span>
</strong>
<strong></strong>
</span>
</p>
<p class="MsoNormal" style=""><strong><span lang="EN-US"><span><span style="font-family: Times New Roman;"><span style="font-size: small;">10、</span>
<span style='font-family: "Times New Roman"; font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal;'> </span>
</span>
</span>
</span>
</strong>
<span style="font-size: small;"><span>Direct-Path INSERT比常规的插入需要更多的空间。因为它将数据插入在高水位之上。并行插入非分区表需要更多的空间,因为它需要为每一个并行线程创建临时段。</span>
</span>
</p>
<p class="MsoNormal" style=""><span lang="EN-US"><span><span style="font-family: Times New Roman;"><span style="font-size: small;">11、</span>
<span style='font-family: "Times New Roman"; font-style: normal; font-variant: normal; font-weight: normal; font-size: 7pt; line-height: normal;'><strong> </strong>
</span>
</span>
</span>
</span>
<span style="font-size: small;"><span>在插入期间,数据库在表上获得排他锁,用户不能在表上执行并行插入、更新或者删除操作,并行的索引创建和build也不被允许。但却可以并行查询,但查询返回的是插入之前的结果集</span>
<span>。</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt;"><span><span style="font-size: small;"><span> </span>
(5)、并行DML:</span>
</span>
</p>
<p><span><span> </span>
如果你的服务器有多个<span lang="EN-US">cpu</span>
,采用<span lang="EN-US">parellel hint</span>
,可以大幅度的提高效率</span>
<span style="font-size: 10.5pt;" lang="EN-US"><br><span></span>
ALTER SESSION ENABLE <span class="hilite3">PARALLEL</span>
DML;</span>
</p>
<p><span style="font-size: 10.5pt;" lang="EN-US"><span> </span>
INSERT /*+ <span class="hilite3">PARALLEL</span>
(tableA, 2) */<span class="hilite2">INTO</span>
tableA <br>
SELECT * FROM tableB;</span>
</p>
<p><span><span> </span>
为了提高速度可以使用下面方法,来减少插入过程中产生的日志:</span>
</p>
<p style="text-indent: 21.1pt;"><span><span></span>
INSERT /*+ <span class="hilite3">PARALLEL</span>
(tableA, 2) */<span class="hilite2">INTO</span>
tableA NOLOGGING<br>
SELECT * FROM tableB;</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt; text-indent: 26.35pt;"><span><span style="font-size: small;"><span style="font-family: Times New Roman;">oracle</span>
默认并不会打开<span style="font-family: Times New Roman;">PDML</span>
,对<span style="font-family: Times New Roman;">DML</span>
语句必须手工启用。即需要执行</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt; text-indent: 26.35pt;"><span><span style="font-size: small;"><span style="font-family: Times New Roman;">alter table enable parallel dml</span>
命令。</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt; text-indent: 26.35pt;"><span lang="EN-US"><span style="font-size: small; font-family: Times New Roman;"></span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt; text-indent: 26.35pt;"><span><span style="font-size: small;">并行<span style="font-family: Times New Roman;">DML</span>
特点:</span>
</span>
</p>
<p class="MsoNormal" style=""><span><span style="font-size: small;"><span style="font-family: Times New Roman;">1</span>
、在并行DML模式中,默认的就是DIRECT-PATH插入,为了运行并行DML模式,必须满足以下条件:</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt; text-indent: 31.6pt; line-height: 150%; text-align: left;" align="left"><span><span style="font-size: small;">a、必须是Oracle企业版;</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt; text-indent: 31.6pt; line-height: 150%; text-align: left;" align="left"><span><span style="font-size: small;">b、必须在session中使并行DML生效,执行以下sql语句:</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt; text-indent: 52.7pt; line-height: 150%; text-align: left;" align="left"><span style="color: #4b4b4b; line-height: 150%; font-family: Verdana;" lang="EN-US"><span style="font-size: small;">ALTER SESSION { ENABLE | FORCE } PARALLEL DML;</span>
</span>
</p>
<p class="MsoNormal" style="" align="left"><span><span style="font-size: small;">c、必须指定table的并行属性,在创建的时候或者其他时候,或者在insert操作时使用“PARALLEL”提示。</span>
</span>
</p>
<p class="MsoNormal" style="" align="left"><span><span style="font-size: small;">d、为了使Direct-Path Insert模式失效,在INSERT语句中指定“NOAPPEND”提示,覆盖并行DML模式。</span>
</span>
</p>
<p class="MsoNormal" style="margin: 0cm 0cm 0pt;"><span style="font-size: small;"><span><span style="font-family: Times New Roman;"><span> </span>
2</span>
、并行Direct-Path INSERT到分区表:</span>
</span>
</p>
<p class="MsoNormal" style=""><span><span style="font-size: small;"><span><span style="font-family: Times New Roman;"> </span>
</span>
类似于serial Direct-Path INSERT,每个并行操作分配给一个或者多个分区,每个并行操作插入数据到各自的分区段的高水位标志之上,commit之后,用户就能看到更新的数据。</span>
</span>
</p>
<p class="MsoNormal" style=""><span><span style="font-size: small;"><span> </span>
3、并行Direct-Path INSERT到非分区表:</span>
</span>
</p>
<p class="MsoNormal" style=""><span><span style="font-size: small;"><span> </span>
每个并行执行分配一个新的临时段,并插入数据到临时段。当commit运行后,并行执行协调者合并新的临时段到主表段,用户就能看到更新的数据。</span>
</span>
</p>
<p class="MsoNormal" style=""><span><span style="font-size: small;"><span> </span>
4、Direct-Path INSERT可以使用Log或者不使用Log。</span>
</span>
</p>
<p class="MsoNormal" style=""><span><span style="font-size: small;"><span> </span>
5、另外不得不说的是,并行不是一个可扩展的特性,只有在数据仓库或作为<span style="font-family: Times New Roman;">DBA</span>
等少数人的工具在批量数据操作时利于充分利用资源,而在<span style="font-family: Times New Roman;">OLTP</span>
环境下使用并行需要非常谨慎。事实上<span style="font-family: Times New Roman;">PDML</span>
还是有比较多的限制的,例如不支持触发器,引用约束,高级复制和分布式事务等特性,同时也会带来额外的空间占用,<span style="font-family: Times New Roman;">PDDL</span>
同<span style="font-family: Times New Roman;"> </span>
样是如此。</span>
</span>
</p>
</span>
</strong>
</p>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值