append与nologging的使用

    技术2026-06-18  9

    select * from v$version;--10.2.0.1.0 首先测试非归档下append,nologging,append+nologging的比较

    1.非归档模式 append,nologging,append+nologging 三种情况数据产生REDO的对比SQL> archive log list数据库日志模式       非存档模式自动存档             禁用存档终点             USE_DB_RECOVERY_FILE_DEST最早的联机日志序列   567当前日志序列        569

    create table t as select * from dba_objects where owner='GWM';select name,value,class from v$sysstat where name='redo size'; --7653452

    insert into t select * from dba_objects;--86894行插入  什么都没使用select name,value,class from v$sysstat where name='redo size'; --17362192

    insert /*+append*/ into t select * from dba_objects;--86894行插入   append的使用select name,value,class from v$sysstat where name='redo size';--17414176

    select (17362192-7653452) redo1,(17414176-17362192) redo2 from dual;         REDO1      REDO2---------- ----------     9708740    51984

     

    drop table t;create table t nologging as select * from dba_objects where owner='GWM';select name,value,class from v$sysstat where name='redo size';--27239040

    insert into t select * from dba_objects;--86894行插入   单独nologging的情况下

    select name,value,class from v$sysstat where name='redo size';--36950884

    insert /*+append*/ into t select * from dba_objects;--86894行插入 append+nologging一起使用

    select name,value,class from v$sysstat where name='redo size';--36994588

     

    select (36950884-27239040) redo1,(36994588-36950884) redo2 from dual;     REDO1      REDO2---------- ----------    9711844       43704

     

     

    再测试归档下append,nologging,append+nologging的比较

    2.归档下:append,nologging,append+nologging 三种情况数据产生REDO的对比select flashback_on from v$database; --NOSQL> archive log list数据库日志模式       存档模式自动存档             启用存档终点            USE_DB_RECOVERY_FILE_DEST最早的联机日志序列   568下一个存档日志序列   570当前日志序列         570SQL> select log_mode from v$database;LOG_MODE------------ARCHIVELOG

    create table t as select * from dba_objects where owner='GWM';select name,value from v$sysstat where name='redo size'; --262896

    insert into t select * from dba_objects;--86894行插入  均无使用append及nologging

    select name,value from v$sysstat where name='redo size';--9975812  使用append

     

    insert /*+append*/ into t select * from dba_objects;--86894行插入  select name,value from v$sysstat where name='redo size';--19765100

    select (9975812-262896) redo1,(19765100-9975812) redo2 from dual;     REDO1      REDO2---------- ----------       9712916    9789288

    truncate table t;alter table t nologging;select name,value from v$sysstat where name='redo size';--19881868

    insert into t select * from dba_objects;--86894行插入  只使用nologgingselect name,value from v$sysstat where name='redo size';--29590564

    insert /*+append*/ into t select * from dba_objects;--86894行插入   使用append和nologging

    select name,value from v$sysstat where name='redo size';--29627424

    select (29590564-19881868) redo1,(29627424-29590564) redo2 from dual;     REDO1      REDO2---------- ----------      9708696        36860

    总结:非归档        append    9708740    51984append与nologging一块使用    9711844    43704归档下        append    9712916    9789288append与nologging一块使用    9708696    36860

    可以看出

    1. 不管哪种模式下append要与nologging方式联用才能达到很好的效果。

    2. 非归档与归档方式,只用NOLOGGING是不起效果的。

    3. 非归档下append已达到不错的效果,但不及与nologging的联用方式。

    4. 归档下单append起不到效果。

    NOLOGGING插完后最好做个备份。

    另外,如果库处在FORCELOGGING模式下,此时的nologging方式是无效的。

     

    最新回复(0)