0

我正在尝试使用 NamedQuery 执行更新,但是尽管更新语句返回了更新的计数,但更新的值并未保留在数据库中。这仅在测试中发生,但在实际流程更新中正在发生。

@Test
@Transactional(propagation = Propagation.REQUIRED, isolation = Isolation.READ_UNCOMMITTED)
public void test() throws Exception 
  messageHandler.process(message);
} catch (Exception e) {
  throw new Exception();
}
assertEquals(new Integer(5), ServiceImpl.findById(100L).get().getStatus());
}

Class MessageHandler{
   @Transactional
   public void process(String message){
       serviceImpl.update(5,100, some date, user);
   }
}

class ServiceImpl {
@PersistenceContext
EntityManager entityManager;
@Modifying(flushAutomatically = true, clearAutomatically = true)
public void updateOrderStatus(Integer newOrderStatus, Long OrderId, String updateTs,
  String updateUserId) {
Query query = entityManager.createNamedQuery(Order.UPDATE_ORDER_STATUS);
entityManager.flush();
query.setParameter(1, newOrderStatus);
query.setParameter(2, OrderId);
query.setParameter(3, updateTs);
query.setParameter(4, updateUserId);
int i = query.executeUpdate();
System.out.println("***************************************");
System.out.println(i);
}
}

谁能帮助我在测试用例中做错了什么?

提前致谢!!!!!!

4

1 回答 1

0

默认情况下,测试事务会回滚。如果您希望测试提交更改,则需要显式使用 @Commit。如果您还没有,请查看spring 文档

于 2019-01-22T13:45:04.567 回答