在数据库打开的情况下备份(归档模式),把表空间或者数据库置于backup 模式下,

如:

SQL> alter database  begin  backup;

Database altered.

那么当把表空间或者数据库置于backup模式下,会发生什么?

1.表空间会发生checkpoint,j将内存中的dirty data全部写进数据文件中;

2.在数据文件头的SCN号会被冻结住;

3.在backup模式下,一个数据块发生了改变,那么整个数据块都会被写进重做数据流中。

所以在backup模式下,是允许用户向数据库中写数据的。

做个试验证明一下,表空间置于backup模式下,用户任然可以修改数据。

没有表空间置于backup 模式下:

打开第一个会话,用sys用户登录,创建一个用户p1,

SQL> create  user p1 identified by  p1_12345 default tablespace users;

User created.

SQL> grant connect,resource to p1;

Grant succeeded.

打开第二个会话,用p1用户登录,创建表fruit,

SQL> insert  into fruit values('apple');

1 row created.

SQL> commit;

Commit complete.

在第一个会话中,

SQL> alter system checkpoint;

System altered.

使数据写到磁盘上;

回到第二个会话中,

SQL> select dbms_rowid.rowid_block_number(rowid) blk,name from  fruit;

BLK         NAME

----------    --------------------------------

814          apple

这是oracle提供的包,由rowid可以看到这个数据文件在哪个数据块上。

通过show parameter db_block_size可以看到它的大小是8192k,

在操作系统中找到users01.dbf(我默认的表空间是users),

[oracle@oracle11g wilson]$ ll /u01/oradata/wilson/users01.dbf

-rw-r----- 1 oracle oinstall 30154752 Aug 23 00:47 /u01/oradata/wilson/users01.dbf

[oracle@oracle11g wilson]$ dd if=users01.dbf ibs=8192 skip=814  count=1 | strings

1+0 records in

16+0 records out

8192 bytes (8.2 kB) copied, 0.000406787 seconds, 20.1 MB/s

U7^M

SUBMIT_COLL_CREDENTIAL_DATA

apple

可以看到apple 被成功的写进了数据文件中。

将users表空间置于backup模式下

SQL> alter tablespace users begin  backup;

Tablespace altered.

看是否可以修改其数据,

在第二个会话中(p1用户),

SQL> update fruit set name='two apple' ;

1 row updated.

SQL> commit;

Commit complete

在第一个会话中(sys用户)中:

SQL> alter system checkpoint;

System altered.

使数据写到磁盘上;

回到第二个会话中,

SQL> select dbms_rowid.rowid_block_number(rowid) blk,name from  fruit;

BLK     NAME

----------  -------------------------------

814     two apple

与上面同样的,在在操作系统中找到users01.dbf,然后

[oracle@oracle11g wilson]$ dd if=users01.dbf ibs=8192 skip=814  count=1 | strings

1+0 records in

16+0 records out

8192 bytes (8.2 kB) copied, 0.000335085 seconds, 24.4 MB/s

U7^M

a}]R

SUBMIT_COLL_CREDENTIAL_DATA

two apple,

apple

可以看到在users表空间在backup模式下,用户任然可以向其中修改数据。(有一点不明白,为什么apple这个数据还在文件中,望高手解答一个)

最后介绍个动态性能视图v$backup,

SQL> select  * from v$backup;

FILE#      STATUS              CHANGE#   TIME

----------  ------------------           ----------      ---------

1        NOT ACTIVE            2794785   23-AUG-13

2        NOT ACTIVE            2794785   23-AUG-13

3        NOT ACTIVE            2794785   23-AUG-13

4        ACTIVE                2798071    23-AUG-13

5        NOT ACTIVE            2794785   23-AUG-13

6        NOT ACTIVE            2794785   23-AUG-13

7        NOT ACTIVE            2794785   23-AUG-13

8        NOT ACTIVE            2794785   23-AUG-13

9        NOT ACTIVE            2794785   23-AUG-13

10        NOT ACTIVE            2794785   23-AUG-13

11        NOT ACTIVE            2794785   23-AUG-13

11 rows selected.

可以看到文件4是active,说明它是处于backup模式下的,但是还是不知道是哪个文件和表空间处于backup模式下。

SQL> select file_id,file_name,tablespace_name from dba_data_files order by file_id;

FILE_ID      FILE_NAME             TABLESPACE_NAME

---------- -----------------------------------      ------------------------------

1 /u01/oradata/wilson/system01.dbf    SYSTEM

2 /u01/oradata/wilson/sysaux01.dbf    SYSAUX

3 /u01/oradata/wilson/undotbs01.dbf   UNDOTBS1

4 /u01/oradata/wilson/users01.dbf     USERS

5 /u01/oradata/wilson/example01.dbf   EXAMPLE

6 /u01/oradata/wilson/paul01.dbf      PAUL

7 /u01/oradata/wilson/sun01.dbf       SUN

8 /u01/oradata/wilson/smallundo1.dbf  SMALLUNDO

9 /u01/oradata/wilson/assm_1.dbf      ASSM

10 /u01/oradata/wilson/mssm_1dbf       MSSM

11 /u01/oradata/wilson/paul02.dbf      PAUL

11 rows selected.

可以看到是users 表空间( /u01/oradata/wilson/users01.dbf)置于backup模式下,这和我们上面做实验时把users表空间置于backup模式下是一致的。

关闭users表空间的backup模式,

SQL> alter tablespace  users end backup;

Tablespace altered.

备注:在backup模式下,可能导致redo log file中的信息量大增(有用户写数据等),影响性能,所以备份完后,快速的end backup,也不推荐使用alter database begin backup命令。

oracle中backup模式的更多相关文章

  1. Oracle中用户(User)和模式(Schema)的概念

    数据库理论中数据库用户和数据库模式并没有必定的联系.具体的数据库模式解释能够在这里找到: http://stackoverflow.com/questions/2674222/what-is-purp ...

  2. 【RMAN】Oracle中如何备份控制文件?备份控制文件的方式有哪几种?

    真题1. 如何备份控制文件?备份控制文件的方式有哪几种? 答案:备份控制文件的方式有多种. ① 备份控制文件可以在线进行: SQL> ALTER DATABASE BACKUP CONTROLF ...

  3. Oracle中的AWR,全称为Automatic Workload Repository

    Oracle中的AWR,全称为Automatic Workload Repository,自动负载信息库.它收集关于特定数据库的操作统计信息和其他统计信息,Oracle以固定的时间间隔(默认为1个小时 ...

  4. 【知识点整理】Oracle中NOLOGGING、APPEND、ARCHIVE和PARALLEL下,REDO、UNDO和执行速度的比较

    [知识点整理]Oracle中NOLOGGING.APPEND.ARCHIVE和PARALLEL下,REDO.UNDO和执行速度的比较 1  BLOG文档结构图 2  前言部分 2.1  导读和注意事项 ...

  5. Oracle中使用REGEXP_SUBSTR,regexp_replace函数

    REGEXP_SUBSTR函数格式如下: function REGEXP_SUBSTR(String, pattern, position, occurrence, modifier)__srcstr ...

  6. 在Oracle中使用Entity Framework 6 CodeFirst

    项目中需要将系统从SQLServer数据库迁移到Oracle上.由于原大部分数据访问操作都是通过包装了Entity Framework的统一访问入口实现的,所以需要研究Entity Framework ...

  7. oracle中imp命令详解 .

    转自http://www.cnblogs.com/songdavid/articles/2435439.html oracle中imp命令详解 Oracle的导入实用程序(Import utility ...

  8. 快速向表中插入大量数据Oracle中append与Nologging

    来源于:http://blog.sina.com.cn/s/blog_61cd89f60102e7gi.html 当需要对一个非常大的表INSERT的时候,会消耗非常多的资源,因为update表的时候 ...

  9. Oracle中如何使用REGEXP_SUBSTR函数

    REGEXP_SUBSTR函数格式如下: function REGEXP_SUBSTR(String, pattern, position, occurrence, modifier) __srcst ...

随机推荐

  1. firefox里面title乱码

    原文:firefox里面title乱码 昨天 在notepad++里面写得文档里面title里面有中文,即使在文档里面写有charset=’UTF-8’, 但是保存后在firefox运行,浏览器标签标 ...

  2. Swift入门教程:基本语法大全

    原文:Swift入门教程:基本语法大全       简介:                                                                        ...

  3. SQL2005性能分析一些细节功能你是否有用到?(三)

    原文:SQL2005性能分析一些细节功能你是否有用到?(三) 继上篇: SQL2005性能分析一些细节功能你是否有用到?(二) 第一: SET STATISTICS PROFILE ON 当我们比较查 ...

  4. The Swift Programming Language-官方教程精译Swift(8)闭包 -- Closures

    闭包是功能性自包含模块,可以在代码中被传递和使用. Swift 中的闭包与 C 和 Objective-C中的 blocks 以及其他一些编程语言中的 lambdas 比较相似. 闭包可以捕获和存储其 ...

  5. 我所理解的Spring AOP的基本概念

    Spring AOP中的概念晦涩难懂,读官方文档更是像读天书,看了非常多样例后,写一些自己理解的一些spring的概念.要理解面向切面编程,要首先理解代理模式和动态代理模式. 如果一个OA系统中的一个 ...

  6. C#中使用REDIS

    C#中使用REDIS 上一篇>> 摘要 上一篇讲述了安装redis客户端和服务器端,也大体地介绍了一下redis.本篇着重讲解.NET4.0 和 .NET4.5中如何使用redis和C# ...

  7. 日志之再说Log4J

    网上关于LOG4J的使用文章太多了,写这篇文章的目的一方面是为了回顾LOG4J的用法,一方面针对配置的使用自动将日志插入数据库,自动发送邮件,还有就是自定义输入实现.后续文章会总结下从LOG4J到LO ...

  8. GIMP也疯狂之动态图的制作(一)

    写在前面的话:本系列gimp教程已首发在Linux吧(Go),之所以重新发表是因为便于博主分类并且可以重新整理,用作记录.本系列的侧重不是GIF的教程,而是gimp教程,想更好的制作GIF图片请使用专 ...

  9. 九度OJ 1035:找出直系亲属(二叉树)

    题目1035:找出直系亲属 时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:1309 解决:521 题目描述: 如果A,B是C的父母亲,则A,B是C的parent,C是A,B的child,如 ...

  10. 我的Android 4 学习系列之使用 Internet 资源

    目录 连接Internet资源 分析XML资源 使用Download Manager下载文件 查询Download manager 使用Account Manager 对 Google App Eng ...