append与nologging的使用
来源:互联网 发布:python 2.7.9 编辑:程序博客网 时间:2024/06/11 10:22
首先测试非归档下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; --NO
SQL> archive log list
数据库日志模式 存档模式
自动存档 启用
存档终点 USE_DB_RECOVERY_FILE_DEST
最早的联机日志序列 568
下一个存档日志序列 570
当前日志序列 570
SQL> 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行插入 只使用nologging
select 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 51984
append与nologging一块使用 9711844 43704
归档下
append 9712916 9789288
append与nologging一块使用 9708696 36860
可以看出
1. 不管哪种模式下append要与nologging方式联用才能达到很好的效果。
2. 非归档与归档方式,只用NOLOGGING是不起效果的。
3. 非归档下append已达到不错的效果,但不及与nologging的联用方式。
4. 归档下单append起不到效果。
NOLOGGING插完后最好做个备份。
另外,如果库处在FORCELOGGING模式下,此时的nologging方式是无效的。
- append与nologging的使用
- append与nologging的使用
- append与nologging的使用
- nologging与append测试
- Oracle中append与Nologging
- oracle 的nologging和append
- nologging的使用
- oracle nologging append 注意
- append+nologging方式
- Oracle Nologging And Append
- 【优化批量插入】nologging和append使用解析
- NOLOGGING 可以使用的场合
- nologging使用
- 表在nologging与logging模式下执行append插入,redo大小差别
- 快速向表中插入大量数据Oracle中append与Nologging
- 快速向表中插入大量数据Oracle中append与Nologging
- 快速向表中插入大量数据Oracle中append与Nologging
- 快速向表中插入大量数据Oracle中append与Nologging
- Java的多线程编程模型之AtomicInteger
- INSERT 优化
- Use TortoiseHg (Mercurial) with SVN repository
- arm立即数
- 老孟 DB2 V9.7 ESE(二)实例及DB创建连接 基于centOS 6.4
- append与nologging的使用
- IE下报 Expected identifier,string or number 错误的解决方法
- 学习新技术的10个建议
- java控制多线程执行顺序
- Linux进程操作——Linux进程线程学习笔记:进程控制
- Python执行系统命令的方法 os.system(),os.popen(),commands
- QWidget析构函数存在的缺陷
- awk 打印行号和整行数据
- POJ 字符窜插入