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