undo管理

本文介绍了Oracle Database 11g中Undo管理的重要性,详细阐述了Undo的作用,包括其在事务回滚、读一致性等方面的关键功能。通过学习,读者将理解如何有效地管理和使用Undo表空间以确保数据库操作的正确性和数据的一致性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

数据库环境:

SQL> select * from v$version;

BANNER

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

Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production

PL/SQL Release 11.2.0.1.0 - Production

CORE 11.2.0.1.0 Production

TNS for Linux: Version 11.2.0.1.0 - Production

NLSRTL Version 11.2.0.1.0 - Production


1.  undo作用

    undo数据也称为回滚数据,用户确保数据的一致性。主要用于回退事务、读一致性、事务恢复、闪回查询
    回退事务:当执行DML操作修改数据时,undo数据被存放到undo段,而新数据则被存放到数据段中,如果事务操作存在问题,需要回退事务,用以取消事务变化。例如用户A执行对emp表,执行delete操作,即delete from emp where empno=‘1’,如果发现错误删除员工号 1,那么就可以通过执行rollback语句取消事务变化。当执行rollback命令时,数据库将undo段的undo数据empno是1的记录回写到数据段中。
    读一致性:当用户检索数据时,oracle只能将已经commit的数据或者特定时间点的数据(select时间点)展示给用户。这样就可以确保数据的一致性。例如,当用户A执行update emp set sal=1  where empno=1时,(备注更新之前 sal是888)undo记录会被存放到回滚段中,而新数据则会存放数据段中,如果此时数据尚未提交,并且用户B执行select sal from emp where empno=1,此时用户B取得是undo数据888。         
    事务恢复:事务恢复是实例恢复的一部分,由oracle server 自动完成的,如果在数据库运行过程中出现实例失败(如断电),那么当重启数据库 时,后台进程smon(system monitor)会自动执行实例恢复,执行实例恢复时,oracle会重新做所有未应用的记录,回退未提交事务。
    闪回查询:用户取的特定时间的数据库数据,用于9i,10g,11g等版本
2.  undo重要参数
 undo_management:该参数指定undo表空间管理方式,分别是auto和manager,默认是auto
undo_retention:该参数指定undo表空数据保留最大时间,默认是900s
undo_tablespace:该参数指定当前的undo表空间
   
    SQL> show parameter undo

NAME				     TYPE	 VALUE
------------------------------------ ----------- ------------------------------
undo_management 		     string	 AUTO
undo_retention			     integer	 9000
undo_tablespace 		     string	 UNDOTBS1
可以通过alter system set【参数名称】=【参数值】进行修改
例如:
SQL> alter system set undo_retention=9000;

System altered.

3. undo表空间
创建undo表空间:create undo tablespace 表空间名称  datafile '文件名称' size 文件大小;
例如:SQL> create undo tablespace undotbs04 
         datafile '/home/oracle/app/oracle/oradata/orcl/undotbs04.dbf' 
          size 50m;

修改undo表空间
a.为undo表空增加数据文件 alter tablespace 表空间名称 add  datafile '文件名称'  size 文件大小
例如:
SQL>  alter tablespace undotbs04 
           add datafile  '/home/oracle/app/oracle/oradata/orcl/undtbs04_01.dbf'
            size 50m;
b.修改undo数据文件大小:alter database datafile '文件名称' resize 文件大小
SQL> alter database datafile '/home/oracle/app/oracle/oradata/orcl/undotbs04.dbf' resize 100M;
c.重命名undo数据文件
步骤1:表空间离线
SQL> alter tablespace undotbs04 offline;
步骤2:在操作系统层面重命名数据文件
[oracle@localhost orcl]$ mv undtbs04_01.dbf undotbs04_01.dbf;
步骤3:用alter tablespace重命名表空间对应的数据文件
SQL> alter tablespace undotbs04 rename datafile '/home/oracle/app/oracle/oradata/orcl/undtbs04_01.dbf' to
     '/home/oracle/app/oracle/oradata/orcl/undotbs04_01.dbf';
步骤4:表空间在线
SQL> alter tablespace undotbs04 online;
删除undo表空间 :drop tablespace 表空间名称
SQL> drop tablespace undotbs04;
备注:数据文件并未真正被删除,需要手动删除
SQL> drop tablespace undotbs2 including contents;
备注:会级联删除数据文件
切换当前undo表空间:alter system set undo_tablespace='表空间名称'
create table t1(i int);
insert into t1 values(1);
insert into t1 values(2);
commit;
create table t2 rowdependencies as select * from t1;


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值