大家在调用toplink的update方法时可能会出现update变成了insert操作的问题:
对于此问题,toplink推荐的update方法流程如下:

1. 通过toplink提供获取对象的方法而不是JDBC的方法来获得需要被更新的对象,并且对此方法配置事务(因为当提交事务以后,toplink的sessioncache才会被更新)
2. 对需要被更新的方法执行更新操作
3. 对此对象执行update方法来更新对象到数据库并更新sessioncache(toplink在执行update方法时会比对sessioncache与需要被更新对象的差别,如果sessioncache不存在,那么toplink会以为是一个新的对象,这样便会执行insert操作了)
exsample:
Public void updateOrder(Order order){
//调用toplink的方法来查询出需要被更新的order
Order updateOrder = **Service.getOrderById(order.getId());
//更新order状态
updateOrder.setStatus(3);
//执行toplink的更新操作
**Service.update(updateOrder);
}
其中getOrderById方法必须配置成有事务的,并且保证在执行update方法时,此事务已经被提交了
本文介绍了使用TopLink更新数据库对象时可能出现的问题,即更新操作意外变成插入操作的情况。为解决这一问题,文章提供了详细的步骤指导,包括如何正确地获取要更新的对象、执行更新操作以及确保事务正确提交。
77

被折叠的 条评论
为什么被折叠?



