菜单 学习猿地 - LMONKEY

VIP

开通学习猿地VIP

尊享10项VIP特权 持续新增

知识通关挑战

打卡带练!告别无效练习

接私单赚外块

VIP优先接,累计金额超百万

学习猿地私房课免费学

大厂实战课仅对VIP开放

你的一对一导师

每月可免费咨询大牛30次

领取更多软件工程师实用特权

入驻
172
0

【spring data jpa】使用spring data jpa 的删除操作,需要加注解@Modifying @Transactional 否则报错如下: No EntityManager with actual transaction available for current thread - cannot reliably process 'remove' call

原创
05/13 14:22
阅读数 52183

使用spring data jpa 的删除操作,需要加注解@Modifying     @Transactional 否则报错如下: No EntityManager with actual transaction available for current thread - cannot reliably process 'remove' call

 

场景如下:

在service中,先执行 delete 操作,再执行 save操作

报错如下:

 No EntityManager with actual transaction available for current thread - cannot reliably process 'remove' call

 

在service层加上事务注解,依旧会报错,而且在执行的sql中可以看到仅执行insert语句,没有执行delete语句

说明delete操作并没有执行,所以在插入的时候,可能出现主键重复,唯一约束重复,报错的情况出现。

 

解决方法:

 

 

@Modifying作用:

(1)可以通过自定义的 JPQL 完成 UPDATE 和 DELETE 操作。 注意: JPQL 不支持使用 INSERT; 
(2)在 @Query 注解中编写 JPQL 语句, 但必须使用 @Modifying 进行修饰. 以通知 SpringData, 这是一个 UPDATE 或 DELETE 操作 
(3)UPDATE 或 DELETE 操作需要使用事务,此时需要定义 Service 层,在 Service 层的方法上添加事务操作; 
(4)默认情况下, SpringData 的每个方法上有事务, 但都是一个只读事务。 他们不能完成修改操作。

发表评论

0/200
172 点赞
0 评论
收藏
为你推荐 换一批