zoukankan      html  css  js  c++  java
  • insert /*+append*/为什么会提高性能

        在上一篇的blog中 做了下使用,在归档和非归档下,做数据插入http://blog.csdn.net/guogang83/article/details/9219479。结论是在非归档模式下表设置为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。

    来源:http://blog.csdn.net/stevendbaguo/article/details/9241481

  • 相关阅读:
    29Mybatis_整合ehcache以及应用场景
    28Mybatis_查询缓存-二级缓存-二级缓存测试-
    27Mybatis_一级缓存的实际应用场景
    解析分布式锁之Zookeeper实现(一)
    程序员的十年工作创业血泪史,万字长文,仔细读完,受益匪浅
    2018 Java线程热门面试题,你知道多少?
    看阿里P9架构师如何向你定义架构及架构师
    程序员30 岁之后:如何实现质的突破?
    强者自救,圣者渡人
    干货:通过双十一等项目实战看架构技术
  • 原文地址:https://www.cnblogs.com/langtianya/p/7892221.html
Copyright © 2011-2022 走看看