Java JPA操作数据,事物控制不完整 clear(),merge()方法分析
最近在使用框架 spring+jpa+cxf 部署一个服务,出现的问题!
事务部分:
在Service的一个方法中,定义好了事务完整性控制
如:
Dao:
public class UserDao{
@PersistenceContext
private EntityManager em;
public User saveOrUpdate(User u){
//code
return em.merge(u);
}
public boolean updateUserBySql(String jpa){
try{
em.createQuery(sql).executeUpdate();
return true;
}catch(Exception e){
return false;
}
}
}
public class UserServiceImpl{
@Autowired
private UserDao userDao;
@Autowired
private TransactionService tranService;
//中间进行缓存基本配置信息的获取(每隔半小时加载一次配置表里面信息)
@Autowired
private CommonService commonService;
public Aresp updateUserTradeOrders(Areq req){
TransactionStatus status = tranService.getTransactionStatus();
try{
User u = XXXX(req); //把req对象变成需要的user对象
String jpa = “update user sql”; //把该用户所有的状态为有效变成无效Sql
boolean bool = userDao.updateUserBySql(jpa);
if(bool){
userDao.saveOrUpdate(u)
}
Aresp a = Aresp.createSuccess();
a.setDesc(commonService.getSysconfig(a.getCode));
transService.commit(status);
return a;
}catch(Exception e){
e.pr;
transService.rollback(status);
return Aresp.createFaild();
}
}
}
CommonService 中方法是每隔半小时进行一个refluse,在refluse时候,会对em进行clear()调用,
提供方法的接口,测试都没有问题! 后来测试时候突然发现半小时一次的,会更新掉用户信息为无效,但是没有把新增的实体保存,出现疑问:
1.虽然我代码不合理,理论应该是先commit在去获取描述语,但是我clear()调用后,也不存在以前有效状态被修改为无效
2. clear()为什么不能把所有的都清楚,都不变动我的数据,执行一半破坏事务的完整性,我使用事务控制的初衷
查看jpa的clear()方式使用和实践:clear()方法分离所有当前正在被管理的实体
em.clear()把实体管理器中所有的实体对象编程游离状态
merge是把实体与数据库同步
通过两点分析,如果。先merge一个不存在库中数据,然后clear 在commit的对象是不会保存到库中,如果库中一开始就存在这条记录的时候,commit后,会被更新
补充:软件开发 , Java ,