iteye_15788
2009-08-14 18:20 阅读 5.4k
已采纳

在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型来判断的,如果抛异常就说明没有成功执行,但是我感觉不太好

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享

3条回答 默认 最新

  • 已采纳
    tou3921 tou3921 2009-08-15 18:25

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

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

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

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

    点赞 评论 复制链接分享
  • Crazy_win Crazy_win 2009-08-15 10:17

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

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

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

    int > 0
    else
    int <= 0

    点赞 评论 复制链接分享
  • wanghaolovezlq wanghaolovezlq 2009-08-25 08:41

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

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

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

    点赞 评论 复制链接分享

相关推荐