鄙人原本打算对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