oracle /+append/好用吗,ORACLE-insert /*+append*/提高性能

在非归档模式下表设置为nologging用insert /*+append*/速度最快。那为什么快呢,原理是什么?下面我们来一起做一个实验:

SQL> create or replace view m_undo_redo as

select v$statname.name,value

from v$mystat, v$statname

where v$mystat.statistic# =v$statname.statistic#

and (v$statname.name =’redo size’

or v$statname.name = ‘undo change vector size’);

视图已创建。

SQL> create table t (x int);

表已创建。

SQL> set timing on

SQL> select * from m_undo_redo;

NAME VALUE

—————————————————————- ———-

redo size 22644

undo change vector size 7484

SQL> insert into t select rownum from dual connect by level <=1000000;

已创建1000000行。

已用时间:  00: 00: 01.03

SQL> commit;

提交完成。

SQL> select * from m_undo_redo;

NAME VALUE

—————————————————————- ———-

redo size 15722456

undo change vector size 2380000

SQL> select (2380000-7484) undo,(15722456-22644) redo from dual;

UNDO REDO

———- ———-

2372516 15699812

SQL> truncate table t;

表被截断。

SQL> select * from m_undo_redo;

NAME VALUE

—————————————————————- ———-

redo size 15781532

undo change vector size 2396672

SQL> insert /*+append*/ into t select rownum from dual connect by level <=1000000;

已创建1000000行。

已用时间:  00: 00: 00.96

SQL> commit;

提交完成。

SQL> select * from m_undo_redo;

NAME VALUE

—————————————————————- ———-

redo size 15871640

undo change vector size 2419196

SQL> select (2419196-2396672) undo,(15871640-15781532) redo from dual;

UNDO REDO

———- ———-

22524 90108

两次的对比:

模式

生成undo

生成redo

普通insert  2372516  15699812

insert /*+append*/ 22524 90108

分析结论:两次对比的结果表示用insert /*+append*/后,数据的undo和redo没有生成。因为HWM 在移动的过程中,这些block是不能被其他process使用的,那么意味着,只要记录下该次direct insert所涉及到的空间的redo 和 undo  ,在失败回滚的时候,只需要把这些空间修改为原来的状态就可以,而不用逐个记录去delete。

原文:https://blog.csdn.net/lee_sire/article/details/54098275

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值