【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页。

相关文章

文章浏览阅读773次,点赞6次,收藏9次。【代码】c# json字符...
文章浏览阅读8.7k次,点赞2次,收藏17次。此现象一般定位到远...
文章浏览阅读2.8k次。mysql脚本转化为oracle脚本_mysql建表语...
文章浏览阅读2.2k次。cx_Oracle报错:cx_Oracle DatabaseErr...
文章浏览阅读1.1k次,点赞38次,收藏35次。本文深入探讨了Or...
文章浏览阅读1.5k次。默认自动收集统计信息的时间为晚上10点...