Wondercease

浙ICP备2022017321号

@Modifying

 JPA中自定义的插入、更新、删除方法要添加@Modifying注解@Transactional注解

@Repository
 public interface UserRepository extends JpaRepository<User,Long> {
 
     @Query(value = "delete from pro_user where id = ?1",nativeQuery = true)
     void deleteUserById(Long id);
 }
x
@Modifying注解
1用@Query注解来将自定义sql语句绑定到自定义方法上。
2可以用@Modifying注解来标注只需要绑定参数的自定义的更新类语句(更新、插入、删除)。
3@Modifying只与@Query联合使用,派生类的查询方法和自定义的方法不需要此注解
4当加上@Modifying注解时,JPA会以更新类语句来执行,而不再是以查询语句执行

@Transactional注解

默认情况下,repository 接口中的CRUD方法都是被@Transactional注解修饰了的,对于读的操作方法@Transactional注解的readOnly属性是被设置为true的,即只读;CRUD中的其他方法被@Transactional修饰,即非只读。如果你需要修改repository 接口中的某些方法的事务属性,可以在该方法上重新加上@Transactional注解,并设置需要的属性。

说明JPA为我们提供的所有方法,包括JPA规则的自定义方法在其底层都为我们做好了事务处理,而我们自定义的方法需要自己来标注事务的类型是只读还是非只读

@Modifying注解补充说明

该注解中有两个属性:flushAutomatically、clearAutomatically,从字面理解是自动刷新和自动清除

自动刷新,即执行完语句后立即将变化内容刷新到磁盘,如果是insert语句操作,则与JPA的 S saveAndFlush(S entity);方法效果相同;

自动清除,即执行完语句后自动清除掉已经过期的实体,比如,我们删除了一个实体,但是在还没有执行flush操作时,这个实体还存在于实体管理器EntityManager中,但这个实体已经过期没有任何用处,直到flush操作时才会被删除掉。如果希望在删除该实体时立即将该实体从实体管理器中删除,则可以将该属性设置为true

发表评论

您的电子邮箱地址不会被公开。