日期:2014-05-16 浏览次数:20512 次
鄙人原本打算对nutz做一个顺序的介绍,zozoh知道后就说:“你这么做不是很有必要,因为用户不如去看wiki,refrence 或者 manual ”。你怎么想呢? 我觉得他说的有道理,于是决定按照乱针绣(一种刺绣针法)的方式来介绍,和大家来交流对nutz的使用和看法。
1.数据库事务
?数据库的事务是作为单个逻辑工作单元执行的一系列操作。一个逻辑工作单元必须有四个属性,称为原子性、一致性、隔离性和持久性 (ACID) 属性,只有这样才能成为一个事务。一般来讲,隔离性是通过锁机制来实现,而其他三个特性通过日志机制实现。
?当一个数据库的某些数据由多个客户端并发访问操作的时候,可能会出现一系列的问题:(1)脏读(dirty read),(2)不可重复读(unrepeatable read),(3)幻象读(phantom read),(4)丢失更新
2.使用Nutz来处理事务
?在nutz中使用一个类org.nutz.trans.Trans来处理事务,使用方式如下:
//TODO 选择事务级别 int level=Connection.TRANSACTION_SERIALIZABLE; Trans.exec(level, new Atom(){ @Override public void run() { //TODO 事务内的操作逻辑 } });
???
??当然你也可是使用如下默认方式:
Trans.exec(new Atom(){ @Override public void run() { //TODO } });
?
??在这种情况下,level默认是Connection.TRANSACTION_READ_COMMITTED
??注:如果你使用jdbc来直接操作事务,当然你可以在某一个位置设置保存点,如果事务失败,可以回滚到那个点,在nutz中整个事务要么成功,要么失败,全部回滚。如果你希望使用savepoint改怎么办呢,你可以这么用:
Dao dao=null; dao.run(new ConnCallback(){ @Override public void invoke(Connection conn) throws Exception { // TODO 在这里面使用Connection来操作 } });
??
??Nutz没有提供其他的接口给用户设置SavePoint,当您使用的时候如果有这种需求,那么请告诉我或者直接给nutz报Bug.
??
????
3.ThreadLocal
?Nutz在实现Trans这个类的时候用到了ThreadLcoal(方便了使用者存储变量到当前线程。),用来存储用户的每一次事务动作。具体实现请参见源代码类org.nutz.trans.Trans。?
?
参考文档:
(1)http://www.iteye.com/topic/103804?page=1
(2)http://hi.baidu.com/splendor518/blog/item/59ea983089567593a8018e34.html