本文主要是通过介绍加速Oracle数据处理的相关实际应用代码来引出加速Oracle数据处理 ,如果你在加速Oracle数据处理 存在不解之处时,你不妨浏览下面的文章,希望你能从中获得自己想要的东西。
让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:空间域名、网络空间、营销软件、网站建设、左权网站维护、网站推广。
一、提高DML操作的办法:
简单说来:
1、暂停索引,更新后恢复.避免在更新的过程中涉及到索引的重建.
2、批量更新,每更新一些记录后及时进行提交动作.避免大量占用回滚段和或临时表空间.
3、创建一临时的大的表空间用来应对这些更新动作.
4、批量更新,每更新一些记录后及时进行提交动作.避免大量占用回滚段和或临时表空间.
5、创建一临时的大的表空间用来应对这些更新动作.
6、加大排序缓冲区
- alter session set sort_area_size=100000000;
- insert into tableb select * from tablea;
- commit;
如果UPDATE的是索引字段,就会涉及到索引的重建,暂停索引不会提高多少的速度,反而有可能降低UPDATE速度,
因为在更新是索引可以提高数据的查询速度,重建索引引起的速度降低影响不大。
ORACLE优化修改参数最多也只能把性能提高15%,大部分都是SQL语句的优化!
update总体来说比insert要慢 :
几点建议:
1、如果更新的Oracle数据量接近整个表,就不应该使用index而应该采用全表扫描
2、减少不必要的index,因为update表通常需要update index
3、如果你的服务器有多个cpu,采用parellel hint,可以大幅度的提高效率
另外,建表的参数非常重要,对于更新非常频繁的表,建议加大PCTFREE的值,以保证Oracle数据块中有足够的空间用于UPDATE, 从而降低CHAINED_ROWS。
二、各种批量DML操作:
(1)、oracle批量拷贝:
- set arraysize 20
- set copycommit 5000
- copy from username/password@oraclename append table_name1
- using select * from table_name2;
(2)、常规插入方式:
- insert into t1 select * from t;
为了提高速度可以使用下面方法,来减少插入过程中产生的日志:
- alter table t1 nologging;
- insert into t1 select * from t;
- commit;
(3)、CTAS方式:
- create table t1
- as
- select * from t;
为了提高速度可以使用下面方法,来减少插入过程中产生的日志,并且可以制定并行度:
- create table t1 nologging parallel(degree 2) as select * from t;
上述的相关内容就是对加速Oracle数据处理的描述,希望会给你带来一些帮助在此方面。
标题名称:Oracle数据处理中的两个操作方案
转载注明:http://www.csdahua.cn/qtweb/news29/237329.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网