nologging 不起作用!【解决】

简介: SQL> conn system/yang as sysdba已连接。SQL> create  or replace  view redo_size  2  as  3  select value  4  from v$mystat m,v$statname s  5  where m.
SQL> conn system/yang as sysdba
已连接。
SQL> create  or replace  view redo_size
  2  as
  3  select value
  4  from v$mystat m,v$statname s
  5  where m.statistic#=s.statistic#
  6* and s.name='redo size'

SQL> select * from redo_size;
     VALUE                                                                     
----------                                                                     
         0      
----------------创建表----------------------------                                                                  
SQL> create table test tablespace test as select * from dba_objects;
表已创建。
SQL> select * from redo_size;
     VALUE                                                                     
----------                                                                     
   8432324                                                                     

SQL> select table_name ,logging,owner from dba_tables where table_name='TEST';
TABLE_NAME                     LOG OWNER                                       
------------------------------ --- ------------------------------               
TEST                           YES SCOTT                                       
TEST                           YES SYS                                          
SQL> show user
USER 为 "SYS"
SQL> insert into test select * from dba_objects;
已创建68982行。
SQL> select * from redo_size;
     VALUE                                                                     
----------                                                                     
  16686608                                                                     
SQL> select (16686608-8432324) redo from dual;
      REDO                                                                     
----------                                                                     
   8254284                                                                     
SQL> insert /*+ append*/ into test select * from dba_objects;
已创建68982行。
SQL> select * from redo_size;
     VALUE                                                                     
----------                                                                     
  25066556                                                                     
SQL> select (25066556-16686608) redo from dual;
      REDO                                                                     
----------                                                                     
   8379948                                                                     
SQL> select (25066556-16686608) redo_append,(16686608-8432324) redo from dual;
REDO_APPEND       REDO                                                         
-----------                ----------                                                         
    8379948
    >     8254284
                                                         
SQL> truncate table test ;
表被截断。
SQL> drop table test ;
表已删除。
----------------创建nologging表----------------------------                                                              

SQL> select * from redo_size;
     VALUE                                                                     
----------                                                                     
  33635864                                                                     
SQL> create table testnolog nologging as select * from dba_objects where 1=0;
表已创建。
SQL> select count(*) from testnolog;
  COUNT(*)                                                                     
----------                                                                     
         0                                                                     
SQL> select * from redo_size;
     VALUE                                                                     
----------                                                                     
  33657684                                                                     
SQL> select table_name,logging,owner
  2  from dba_tables where table_name='TESTNOLOG';
TABLE_NAME                     LOG OWNER                                       
------------------------------ --- ------------------------------               
TESTNOLOG                      NO  SYS                                          
SQL> select * from redo_size;
     VALUE                                                                     
----------                                                                     
  33657684                                                                     
SQL> insert into testnolog select * from dba_objects;
已创建68982行。
SQL> select * from redo_size;
     VALUE                                                                     
----------                                                                     
  41941584                                                                     
SQL> insert [b ]/*+append*/ into testnolog select * from dba_objects;
已创建68982行。
SQL> select * from redo_size;
     VALUE                                                                     
----------                                                                     
  50298684                                                                     
SQL> select (50298684-41941584) redo_append,(41941584-33657684) redo from dual;
REDO_APPEND       REDO                                                         
-----------              ----------                                                         
    8357100            8283900          
 
原因:
   以前在测试机上做了dataguard 的实验,数据库为Force Logging模式。
    指定数据库为Force Logging模式后,数据库将会记录除临时表空间或临时回滚段外所有的操作,而忽略类似NOLOGGING之类的指定参数。

目录
相关文章
|
SQL Oracle 关系型数据库
flashback table肯定会造成rowid跟着修改
flashback table肯定会造成rowid跟着修改,为什么要开启行移动?
|
Oracle 关系型数据库 Linux
[20171231]PLSQL使用绑定变量.txt
[20171231]PLSQL使用绑定变量.txt --//一些应用程序开发使用的绑定变量是:1,:2之列的语句,要调优这些语句必须写成如下: 1.环境: SCOTT@book> @ &r/ver1 PORT_STRING              ...
1205 0
|
Oracle 关系型数据库
|
Oracle 关系型数据库 数据库管理
|
机器学习/深度学习 SQL Oracle
【知识点整理】NOLOGGING、APPEND、ARCHIVE和PARALLEL下,REDO、UNDO和执行速度的比较
【知识点整理】Oracle中NOLOGGING、APPEND、ARCHIVE和PARALLEL下,REDO、UNDO和执行速度的比较 1  BLOG文档结构图     2  前言部分 2.
1197 0
|
SQL 存储 Oracle
【IMPDP】使用 TRANSFORM选项去掉表空间和存储子句
使用IMPDP工具完成数据导入时,会按照dump文件中有关的存储的参数信息完成数据的导入。很多情况下我们希望按照被导入用户的默认参数完成数据的导入,此时我们可以使用IMPDP的TRANSFORM参数辅助完成。
1213 0

热门文章

最新文章