为什么要添加@Transactional和@Modifying注解

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

By default, CRUD methods on repository instances are transactional. For read operations, the transaction configuration readOnly flag is set to true. All others are configured with a plain @Transactional so that default transaction configuration applies. For details, see JavaDoc of SimpleJpaRepository.

实质上@Modifying只是声明了这个操作是一个修改操作,但却没有修改这个方法的事务等级,因此这个方法依然不能进行修改操作。只有声明了@Transactional,本质上是声明了@Transactional(readOnly=false),这样覆盖了默认的@Transactional配置便可以执行修改操作了。

一、@Modifying注解
@Modifying
@Query("update User u set u.firstname = ?1 where u.lastname = ?2")
int setFixedFirstnameFor(String firstname, String lastname);

1.@Query注解来将自定义sql语句绑定到自定义方法上。
2.@Modifying注解来标注只需要绑定参数的自定义的更新类语句(更新、插入、删除)。
3.@Modifying只与@Query联合使用,派生类的查询方法和自定义的方法不需要此注解。
4.@Modifying注解时,JPA会以更新类语句来执行,而不再是以查询语句执行。

也就是说,当我们要通过自已写的更新、插入、删除SQL语句来实现更新、插入、删除操作时,至少需要用两个步骤:

1)@Query来注入我们自定义的sql;

2)使用@Modifying来标注是一个更新类的自定义语句。

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

@Transactional注解的readOnly默认的属性的false,即非只读,当一个事务是非只读事务的时候,我们可以进行任何操作。
 

你可能感兴趣的:(java,数据库,开发语言)