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

本文探讨了如何通过调整DML操作、利用批量操作、参数优化以及数据库设计策略来提升Oracle在处理大规模数据时的性能。关键建议包括暂停索引更新、批量提交、调整sort_area_size、优化SQL语句和参数设置。还介绍了批量DML操作的方法,如批量拷贝和高效插入策略。
摘要由CSDN通过智能技术生成

如何加速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、如果更新的数据量接近整个表,就不应该使用index而应该采用全表扫描

2、减少不必要的index,因为update表通常需要update index

3、如果你的服务器有多个cpu,采用parellel hint,可以大幅度的提高效率

另外,建表的参数非常重要,对于更新非常频繁的表,建议加大PCTFREE的值,以保证数据块中有足够的空间用于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 nol

相关文档:

783. ALL_ALL_TABLES

用户可存取的所有表.

784. ALL_ARGUMENTS

用户可存取的对象的所有参数.

785. ALL_ASSOCIATIONS

用户定义的统计信息.

786. ALL_BASE_TABLE_MVIEWS

用户可存取的所有物化视图信息.

787. ALL_CATALOG

用户可存取的全部表,同义词,视土和序列.

788. ALL_CLUSTER_HASH_EXPRESSIONS

用户可存取的聚 ......

本文节选自《Oracle DBA手记——数据库诊断案例与性能优化实践》第2章“Yangtingkun的DBA工作手记” (作者:杨廷琨)

V$SQL视图显示结果异常的诊断

有一次碰到一个很奇怪的问题,在检查会话所执行的SQL时,发现V$SQL视图中SQL_TEXT列中的数据是不正常的。

由于V$SQL是动态性能视图,里面保存的是当 ......

sqlserver和oracle常用函数对比

数学函数

1.绝对值

S:select abs(-1) value

O:select abs(-1) value from dual

2.取整(大)

S:select ceiling(-1.001) value

O:select ceil(-1.001) value from dual

3.取整(小)

S:select floor(-1.001) value

O:select floor(-1.0 ......

最近总结了一下oracle主键的设置方法,贴到这保存一下吧。 有两种方法可以设置主键,一种是自增长主键,另一种就是生成唯一序列。 一、自增长主键 --首先建一个表TEST

create tableTEST (

NID int PRIMARY KEY,

test1 varchar2(20),

test2 varchar2(20),

test3 ......

--当请求执行后不能"查看输出"的时候表示有进程死锁了

--查找死锁的进程

select t2.username,t2.sid,t2.serial#,t2.logon_time

from v$locked_object t1,v$session t2

where t1.session_id=t2.sid order by t2.logon_time

--删除死锁的进程,删除当天前的,不能删除当天的,

--alter system kill session 't2.sid,t ......

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值