Spring boot jpa 删除数据和事务管理的问题实例详解
今天我们介绍的是jpa删除和事务的一些坑,接下来看看具体内容。
业务场景(这是一个在线考试系统)和代码:根据问题的id删除答案
repository层:
intdeleteByQuestionId(IntegerquestionId);
service层:
publicvoiddeleteChoiceAnswerByQuestionId(IntegerquestionId){ choiceAnswerRepository.deleteByQuestionId(questionId);
测试层:
@Test publicvoidtestDeleteByQuestionId(){ 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:NoEntityManagerwithactualtransactionavailableforcurrentthread-cannotreliablyprocess‘remove'call;nestedexceptionisjavax.persistence.TransactionRequiredException:NoEntityManagerwithactualtransactionavailableforcurrentthread-cannotreliablyprocess‘remove'call
当我们除了query外的modiy和delete外如果没有各层的方法中进行事务管理的话也就是没加@Transactional话会报错
问题2:只在test层加@Transactional
没有错误但是数据并没有被删除,在用IDEA的调试是,在执行这个测试方法的过程时还可以在choiceanswer表中进行操作并没有加锁事务并没有起作用
问题3:只在Repository层加@Transactional
publicvoiddeleteChoiceAnswerByQuestionId(IntegerquestionId){ 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);
数据里面被修改
问题4:只在service层加@Transactional
当只有执行完service内的对应方法时数据才会被删除
问题5:在service层和Repository都加上@transactional
当只有执行完service内的对应方法时数据才会被删除
问题6:只要在test(或者是除了service层和Repository层)加上@Transactional,不管service层和Repository层加不加@Transactional数据都不会被删除
问题7:
@Modifying @Query(“deletefromChoiceAnswercwherec.question.id=?1“) @Transactional intdeleteByQuestionId(IntegerquestionId);
与
@Transactional intdeleteByQuestionId(IntegerquestionId);
有什么区别,上面的会直接执行delete语句
下面的会先执行select再执行delete
总结:
事务管理只有在service加上事务管理才起作用,query不需要事务管理但是deleteupdate但需要事务管理为了不在Service层不加事务管理可以再Repository层的deleteuodate加上@transactional但这样不能真正保持事务的完整性.
本文关于Springbootjpa删除数据和事务管理的问题实例详解的介绍就到这里,希望对大家有所帮助,欢迎大家参阅本站其他专题。