【Oracle】再看事务

前端之家收集整理的这篇文章主要介绍了【Oracle】再看事务前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

事务(Transaction):数据库区别于文件系统的特性之一。
事务会把数据库从一种一致状态转变为另一种一致状态,这就是食物的任务。
Oracle多版本控制机制提供了非阻塞读,以及读写一致性。

回顾下oracle的锁:

  • AE锁是一个版本锁,这是oracle 11g新增的。
  • TX(事务处理锁):修改数据的事务在执行期间会获得这种锁。
  • TM(DML队列)锁和DDL锁:在你修改一个对象的内容(对应TM锁)或对象本身(对应DDL锁)时,这些锁可以确保对象的结构不被修改
  • 闩(latch)和Mutex:这是Oracle的内部锁,用来协调对其共享数据结构的访问。

回顾下事务隔离级别:
ANSI隔离级别

隔离级别 脏读 不可重复读 幻象读
READ UNCOMMITTED 允许 允许 允许
READ COMMITTED 允许 允许
REPEATABLE READ 允许
SERIALIZABLE

隔离级别的3中情况
- 脏读(dirty read):你能读取未提交的数据,也就是脏数据。
- 不可重复读(nonrepeatable read):这意味着,如果你在T1时间读取某一行,在T2时间重新读取这一行时,这一行可能已经有所修改,也许它已经消失,也可能被更新了。
- 幻象读(phantom read):如果你在T1时间执行一个查询,在T2时间再次执行这个查询,此时数据库中可能已经增加了行。与不可重复读的区别是:读取的数据不会改变,只是有了更多的数据。

Oracle支持READ UNCOMMITTED的”精神“,即非阻塞读。但不支持脏读[1]。


[1] Oracle_Database_9i10g11g编程艺术深入数据库体系结构第2版221页。

原文链接:https://www.f2er.com/oracle/212810.html

猜你在找的Oracle相关文章