jpa @query insert 参数为实体
时间: 2023-12-08 18:04:18 浏览: 218
使用JPA时@Query中的insert语句之对象传参
JPA @Query 注解也可以用于执行 INSERT 操作,并且参数为实体。下面是一个示例:
```java
@Repository
public interface UserRepository extends JpaRepository<User, Long> {
@Modifying
@Query("INSERT INTO User(name, age) VALUES (:name, :age)")
void insertUser(@Param("user") User user);
}
```
在这个示例中,我们定义了一个 UserRepository 接口,它继承了 JpaRepository 接口。我们在接口中定义了一个 insertUser 方法,使用 @Query 注解指定了要执行的 INSERT 语句。@Modifying 注解用于标记这个方法会修改数据库,而 @Param 注解用于指定参数的名称。
与之前的示例不同的是,这次我们的 insertUser 方法接受一个 User 对象作为参数。在 SQL 语句中,我们使用 ":user.name" 和 ":user.age" 分别表示 User 对象的 name 和 age 属性。JPA 会自动将传入的 User 对象的属性值绑定到 SQL 语句中,执行插入操作。
使用这个方法时,我们可以直接调用 insertUser 方法,传入一个 User 对象即可。JPA 会自动将 User 对象的属性值绑定到 SQL 语句中,执行插入操作。
阅读全文