jpa里一个事务里修改完数据又从别的实体做关联查询的问题

        Voyage voyage = Voyage.findByVoyageNo(condition.getVoyageNo(), condition.getShipNameCn());
        //没有被处理过的航次才会处理
        if(voyage!=null&&voyage.getFlag()!=IsFlag.TRUE){
        voyage.setFlag(IsFlag.TRUE);
        // 获取入库单详单数据

        List<InboundDetail> inboundDetailList = InboundDetail.findByCondition(condition);

      此方法前没有任务别的方法操作,但是在InboundDetail里有voyage的关联关系,此查询的hql里包含有关联查询

findByConditionQueryStr.append(" AND inboundDetail.voyage.voyageNo = :voyageNo ");

    实际运行时数据库会在 InboundDetail.findByCondition(condition)处卡住,表被锁定

              如果将voyage.setFlag(IsFlag.TRUE);语句放置在查询 InboundDetail.findByCondition(condition);后则没有问题,程序能正常运行。

             初步估计是因为事务切在该方法上,voyage.setFlag(IsFlag.TRUE);会锁表但是不会提交事务。

              

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值