jfinal mysql 事务_JFinal 数据库“手动”事务(提交、回滚)

本文介绍了两种在JFinal中处理MySQL事务的方法:一是使用`@Before(Tx.class)`注解实现自动回滚,这种方法简单但不能细致处理返回数据和异常;二是通过`Db.tx(IAtom)`方法,可以自定义事务提交或回滚条件,并能返回业务状态。推荐使用第二种方法,尤其是在需要精细化控制事务和返回值的情况下。
摘要由CSDN通过智能技术生成

一、用注解 @Before(Tx.class) 实现 事务回滚

@Before(Tx.class)

public void pay() throws Exception {

//throws exception;

}

方法体不能扑捉异常,所有的异常都抛出,当出现异常时事物将回滚(即 事务的回滚 是依赖 抛出异常 来实现的)

优点:简单暴力,不需要去处理每个异常,直接抛出即可;

缺点:不能详细的区分返回数据、视图,只能笼统的报出异常;

二、Db.tx(new IAtom(){})

public void pay() {

final Map map = new HashMap();

boolean bl = Db.tx(new IAtom() {

@Override

public boolean run() throws SQLException {

if (...) {

//...

return false;

} else {

...

return true;

}

return true;

}

});

this.rendJson(bl, null, map.get("return_words"), null);

}

return false 或者 有异常抛出 都会 回滚事务,return true 才会提交事务;

Db.tx 方法是有返回值true/false,可对该 返回值 作为 业务返回;

如果想让 run() 方法中往外层传递变量,可以在外层定义一个 final 修饰的 容器类的对象 或者 定义map;

方法二较方法一更全面,处理更细腻,推荐使用二。

注意:方法二可简写(Java8语法)

public void pay() {

final Map map = new HashMap();

boolean bl = Db.tx(() -> {

if (...) {

//...

return false;

} else {

...

return true;

}

return true;

});

this.rendJson(bl, null, map.get("return_words"), null);

}

参考:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值