这两天闲来无事,从[url=http://www.infoq.com/cn]infoQ[/url]下载了[i]javatransactionsbook.pdf[/i]看看。这本书写的还是蛮直白的,很多知识都比较常见,正好巩固一下自己并不扎实的基础。
事务(transaction)分三种类型
[b]Local transaction model [/b]
只能用来操作connetion,不适用于transaction.譬如说,
一般用于小型的应用,不足之处在于开发人员处理transaction时需要非常小心。还有一点就是无法加入到XA事务中去。
[b]Programmatic transaction model [/b]
基本与前者相似,区别在于前者控制connection,后者使用transaction.
一般用于BMT事务,当然也可用于client端控制多个业务方法,进而达到事务控制。
[b]Declarative transaction model[/b]
比较常见的是EJB的CMT事务。
当然有一点需要注意的是对于application exception,需要手动的SessionContext。setRollbackOnly,否则的话容器不会回滚。还有一种做法是将application exception包装成EJBException,这样的话也可以达到回滚的效果,只不过回传到client的exception比较冗长不直观。
按理说DDL是不能回滚的。我尝试过在SQLServer中可行,但是Oracle不能,奇怪?
补充一下一直比较混淆的概念:
- JTA
- JTS
The relationship of JPA and JTS is similar as JDBC and JDBC driver.One is spec,another is implementation.
pdf继续阅读中 :lol:
事务(transaction)分三种类型
[b]Local transaction model [/b]
只能用来操作connetion,不适用于transaction.譬如说,
conn = getConnection();
conn.setAutoCommit(false);
. . .
conn.commit()/rollback();
一般用于小型的应用,不足之处在于开发人员处理transaction时需要非常小心。还有一点就是无法加入到XA事务中去。
[b]Programmatic transaction model [/b]
基本与前者相似,区别在于前者控制connection,后者使用transaction.
UserTransaction ut = getUserTransaction() ;// loop up JNDI
ut.begin();
ut.rollback()/commit();
一般用于BMT事务,当然也可用于client端控制多个业务方法,进而达到事务控制。
[b]Declarative transaction model[/b]
比较常见的是EJB的CMT事务。
当然有一点需要注意的是对于application exception,需要手动的SessionContext。setRollbackOnly,否则的话容器不会回滚。还有一种做法是将application exception包装成EJBException,这样的话也可以达到回滚的效果,只不过回传到client的exception比较冗长不直观。
按理说DDL是不能回滚的。我尝试过在SQLServer中可行,但是Oracle不能,奇怪?
补充一下一直比较混淆的概念:
- JTA
- JTS
The relationship of JPA and JTS is similar as JDBC and JDBC driver.One is spec,another is implementation.
pdf继续阅读中 :lol: