Oracle回滚段的概念,用法和规划及问题的解决
来源:互联网 发布:修改hosts文件软件 编辑:程序博客网 时间:2024/05/20 02:54
回滚段管理一直是ORACLE数据库管理的一个难题,本文通过实例介绍ORACLE回滚段的概念,用法和规划及问题的解决。
回滚段概述
回滚段用于存放数据修改之前的值(包括数据修改之前的位置和值)。回滚段的头部包含正在使用的该回滚段事务的信息。一个事务只能使用一个回滚段来存放它的回滚信息,而一个回滚段可以存放多个事务的回滚信息。
回滚段的作用
事务回滚:当事务修改表中数据的时候,该数据修改前的值(即前影像)会存放在回滚段中,当用户回滚事务(ROLLBACK)时,ORACLE将会利用回滚段中的数据前影像来将修改的数据恢复到原来的值。
事务恢复:当事务正在处理的时候,例程失败,回滚段的信息保存在重做日志文件中,ORACLE将在下次打开数据库时利用回滚来恢复未提交的数据。
读一致性:当一个会话正在修改数据时,其他的会话将看不到该会话未提交的修改。而且,当一个语句正在执行时,该语句将看不到从该语句开始执行后的未提交的修改(语句级读一致性)。当ORACLE执行SELECT语句时,ORACLE依照当前的系统改变号(SYSTEM CHANGE NUMBER-SCN)来保证任何前于当前SCN的未提交的改变不被该语句处理。可以想象:当一个长时间的查询正在执行时,若其他会话改变了该查询要查询的某个数据块,ORACLE将利用回滚段的数据前影像来构造一个读一致性视图。
事务级的读一致性
ORACLE一般提供SQL语句级(SQL STATEMENT LEVEL)的读一致性,可以用以下语句来实现事务级的读一致性。
SET TRANSACTION READ ONLY;
或:
SET TANNSACTION SERIALIZABLE;
以上两个语句都将在事务开始后提供读一致性。需要注意的是,使用第二个语句对数据库的并发性和性能将带来影响。
回滚段概述
回滚段用于存放数据修改之前的值(包括数据修改之前的位置和值)。回滚段的头部包含正在使用的该回滚段事务的信息。一个事务只能使用一个回滚段来存放它的回滚信息,而一个回滚段可以存放多个事务的回滚信息。
回滚段的作用
事务回滚:当事务修改表中数据的时候,该数据修改前的值(即前影像)会存放在回滚段中,当用户回滚事务(ROLLBACK)时,ORACLE将会利用回滚段中的数据前影像来将修改的数据恢复到原来的值。
事务恢复:当事务正在处理的时候,例程失败,回滚段的信息保存在重做日志文件中,ORACLE将在下次打开数据库时利用回滚来恢复未提交的数据。
读一致性:当一个会话正在修改数据时,其他的会话将看不到该会话未提交的修改。而且,当一个语句正在执行时,该语句将看不到从该语句开始执行后的未提交的修改(语句级读一致性)。当ORACLE执行SELECT语句时,ORACLE依照当前的系统改变号(SYSTEM CHANGE NUMBER-SCN)来保证任何前于当前SCN的未提交的改变不被该语句处理。可以想象:当一个长时间的查询正在执行时,若其他会话改变了该查询要查询的某个数据块,ORACLE将利用回滚段的数据前影像来构造一个读一致性视图。
事务级的读一致性
ORACLE一般提供SQL语句级(SQL STATEMENT LEVEL)的读一致性,可以用以下语句来实现事务级的读一致性。
SET TRANSACTION READ ONLY;
或:
SET TANNSACTION SERIALIZABLE;
以上两个语句都将在事务开始后提供读一致性。需要注意的是,使用第二个语句对数据库的并发性和性能将带来影响。
- Oracle回滚段概念用法规划及问题的解决
- Oracle回滚段的概念,用法和规划及问题的解决
- Oracle回滚段的概念,用法和规划及问题的解决
- ORACLE回滚段的概念,用法和规划及问题的解决
- Oracle回滚段的概念,用法和规划及问题的解决
- Oracle回滚段的概念,用法和规划及问题的解决
- Oracle回滚段概念用法规划及问题的解决 (2)
- ORACLE expdp与impdp用法整理及高导低版本问题的解决
- ORACLE expdp与impdp用法整理及高导低版本问题的解决
- Linux--用户和组的概念及用法
- Edge Components 的概念、规划和安装
- oracle clob 和blob问题的解决
- Typeof 的概念和用法
- 归档的概念和用法
- 动态规划的概念
- 动态规划的概念
- linux下c++使用occi连接oracle数据库步骤,及出现的问题和解决
- Oracle数据导出遇到的问题及解决的办法
- excel在QTP中实现自动化
- gdb调试C++ STL
- Linux rpm 命令参数使用详解[介绍和应用]
- 存储过程的output及return的区别
- 自定义的eclipse editor 保存文件中文失败
- Oracle回滚段的概念,用法和规划及问题的解决
- 利用信号实现写优先的读写锁
- bss段、数据段、代码段、堆、栈
- Switch结构
- 内核模式下我们能调用哪些函数?
- extent
- Web service 的具体过程
- 对hibernate的set集合进行排序
- 将现有程序改造为OLE服务器供包容器(word,ppt)使用