在service层里调用了dao的两个方法,如何保证这两个方法执行在同一个事务中呢?

在service层里调用了dao的两个方法,如何保证这两个方法执行在同一个事务中呢?

问题描述:

service里有如下方法
Java code@Transactional(rollbackFor = Exception.class)
public boolean del(Integer id) {
boolean b = false;
b = backDao.del(id);
Back bs = new Back();
bs.setUserName(null);
backDao.save(bs);
return b;
}

我想实现的是只用当删除和保存都正确的情况下,才持久化到数据库中去,现在我调用这个del方法时,保存明显是错误的,插入不到数据库中去,而且后台也报错了,但是还是可以删除操作的

dao中方法如下,继承了SqlMapClientDaoSupport

Java codepublic boolean delete(final String sqlId, final PK pk) {
boolean flag = false;
try {
this.getSqlMapClientTemplate().delete(sqlId, pk);
flag = true;
} catch (Exception e) {
e.printStackTrace();
}
return flag;
}

public boolean save(final String sqlId, final T entity) {
boolean flag = false;
try {
this.getSqlMapClientTemplate().insert(sqlId, entity);
flag = true;
} catch (Exception e) {
e.printStackTrace();
}
return flag;
}

还有一个问题,怎么能保证save,del等方法正确执行呢,我是用返回一个boolean型来判断的,如果抛异常就说明没有成功执行,但是我感觉不太好

你可以看下spring的文档。
引用一下原文:
[quote]
Spring框架的事务基础架构代码将默认地 只 在抛出运行时和unchecked exceptions时才标识事务回滚。 也就是说,当抛出一个 RuntimeException 或其子类例的实例时。(Errors 也一样 - 默认地 - 标识事务回滚。)从事务方法中抛出的Checked exceptions将 不 被标识进行事务回滚。

可以配置哪些 Exception类型将被标识进行事务回滚。
.....
[/quote]

所以你的service调用的dao,dao不要捕获异常,并且你在dao层捕获异常也没什么意义,你也只是print出来。

你在service层捕获异常是可以回滚的。具体特例还需要自己动手测测。

给点建议,错了莫怨!! :)

首先,删除和保存方法都是有返回值的,

boolean flag = false;
try {
this.getSqlMapClientTemplate().insert(sqlId, entity);
flag = true;
} catch (Exception e) {
e.printStackTrace();
}
return flag;
这样写肯定是无意义的,一般都是返回int类型的返回值,
如果操作成功

int > 0
else
int <= 0

你只给service的方法配置事务,但不给dao的方法配置事务,那就能保存service调用dao的n个方法都在同一个事务中

你应该让dao层把异常向service层抛,由它来回滚事务,因为它是事务发起者,

因为dao层抛异常也就是操作数据库出错,这就表示这个操作单元是失败的,你不回滚事务,那数据库数据可能就不一致