`
arron.huang
  • 浏览: 31602 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

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后,会被更新

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics