Transaction Scope
通过跟踪方法执行的前因后果,可以很容易地对事务范围进行跟踪。
异常可能会引起事务的回滚,也可能不会,这要取决于异常的具体的类型。
方法执行的线索并不是决定EJB是否包含在事务范围内的唯一考量;EJBde事务属性也起了非常重要的作用。
事务属性
EJB端点和事务属性
Mandatory事务属性不能用于EJB端点(endpoints),因为EJB端点是不能传播客户端事务的。
事务的传播
如果方法抛出了一个系统异常或需要回滚的应用异常,则事务将会被自动回滚。
并发性访问导致的问题
Dirty、Repeatable,and Phantom Reads
事务的隔离性是由隔离条件进行定义的,隔离条件包括脏读、可重复读和幻读。
脏读(dirty reads)
当某个事务已更新一份数据,另一个事务在此时读取了同一份数据,由于某些原因,前一个Roll back 了操作,
则后一个事务所读取的数据就会是不正确的。
不可重复读(non-repeatable reads)
在一个事务的两次查询中数据不一致,这可能是因为两次查询过程中间插入了一个事务更新的原有的数据。
幻读(phantom read)
在一个事务的两次查询中数据笔数不一致,例如有一个事务查询了几行(Row)数据,而另一个事务却在此时插入了新的几列数据,先前的事务在接下来的查询中,就会发现有几列是它先前没有的。
解决方法:锁机制
读锁:避免重复读
写锁:允许脏度
排他写所:拒绝脏读
快照:可避免脏读、不可重复读和幻读。不过由于这些快照不是实时的,因而也会有问题。
事务的隔离级别
Read Uncommitted
Read Committed
Repeatable Read
Serializable