源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Spring boot jpa 删除数据和事务管理的问题实例详解

  • 时间:2020-06-28 10:11 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Spring boot jpa 删除数据和事务管理的问题实例详解
今天我们介绍的是jpa删除和事务的一些坑,接下来看看具体内容。 业务场景(这是一个在线考试系统)和代码:根据问题的id删除答案 [b]repository层:[/b]
int deleteByQuestionId(Integer questionId);
[b]service 层:[/b]
public void deleteChoiceAnswerByQuestionId(Integer questionId) {
choiceAnswerRepository.deleteByQuestionId(questionId);
[b]测试层:[/b]
@Test
public void testDeleteByQuestionId() {
 choiceAnswerService.deleteChoiceAnswerByQuestionId(5);
 System.out.println("hehehhe");
 System.out.println("hehehhe");
 System.out.println("hehehhe");
 System.out.println("hehehhe");
 System.out.println("hehehhe");
 System.out.println("hehehhe");
 System.out.println("hehehhe");
}
问题1:如果各层都不加事务管理的话 @Transactional 会报这个错误 org.springframework.dao.InvalidDataAccessApiUsageException: No EntityManager with actual transaction available for current thread - cannot reliably process ‘remove' call; nested exception is javax.persistence.TransactionRequiredException: No EntityManager with actual transaction available for current thread - cannot reliably process ‘remove' call 当我们除了query外的modiy和delete外如果没有各层的方法中进行事务管理的话也就是没加@Transactional话会报错 [b]问题2:[/b]只在test层加@Transactional 没有错误但是数据并没有被删除,在用IDEA的调试是,在执行这个测试方法的过程时还可以在choiceanswer表中进行操作并没有加锁事务并没有起作用 [b]问题3:[/b]只在 Repository层加@Transactional
public void deleteChoiceAnswerByQuestionId(Integer questionId) {
choiceAnswerRepository.deleteByQuestionId(questionId);
System.out.println(“hehehhe”);
System.out.println("hehehhe");
// questionRepository.delete(5);
System.out.println(“hehehhe”);
 System.out.println("hehehhe");
 System.out.println("hehehhe");
 System.out.println("hehehhe");
 System.out.println("hehehhe");
}
这时当执行完
choiceAnswerRepository.deleteByQuestionId(questionId);
数据里面被修改 [b]问题4[/b]:只在 service层加@Transactional 当只有执行完service内的对应方法时数据才会被删除 [b]问题5[/b]:在service 层和Repository都加上@transactional 当只有执行完service内的对应方法时数据才会被删除 [b]问题6:[/b]只要在test(或者是除了service层和Repository层)加上@Transactional,不管service层和Repository层加不加@Transactional数据都不会被删除 [b]问题7:[/b]
@Modifying
@Query(“delete from ChoiceAnswer c where c.question.id=?1 “)
@Transactional
int deleteByQuestionId(Integer questionId);
@Transactional
int deleteByQuestionId(Integer questionId);
有什么区别,上面的会直接执行delete语句 下面的会先执行select 再执行delete [b]总结:[/b] 事务管理只有在service加上事务管理才起作用,query不需要事务管理但是delete update但需要事务管理为了不在Service层不加事务管理可以再Repository层的delete uodate加上@transactional 但这样不能真正保持事务的完整性. 本文关于Spring boot jpa 删除数据和事务管理的问题实例详解的介绍就到这里,希望对大家有所帮助,欢迎大家参阅本站其他专题。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部