使用JPA中@Query 注解实现update 操作

spring使用jpa进行update操作主要有两种方式:

1、调用保存实体的方法

1)保存一个实体:repository.save(T entity)

2)保存多个实体:repository.save(Iterable<T> entities)

3)保存并立即刷新一个实体:repository.saveAndFlush(T entity)

注:若是更改,entity中必须设置了主键字段,不然不能对应上数据库中的记录,变成新增(数据库自动生成主键)或报错(数据库不自动生成主键)了

2、@Query注解,自己写JPQL语句

使用JPA中@Query 注解实现update 操作,代码如下:
@Transactional
@Modifying(clearAutomatically = true)
 @Query(value = "update StockOut sc set sc.receivedPersonId=?1,sc.receivedPerson=?2,sc.receivedDate=?3 where stockOutCode=?4")
 int receipt(Long uid,  String uname, Date createDate, String soCode);
备注:
1.更新StockOut表下一些字段, 这里使用了不是原生的sql语句,所以不要加nativeQuery = true
2.@Transactional 注解用于提交事务,若没有带上这句,会报事务异常提示。
3.@Modifying(clearAutomatically = true) 自动清除实体里保存的数据。
假设我们有一个实体类 `Person`,其包含 `id` 和 `name` 两个字段,我们要实现对一组 `Person` 对象进行批量插入或更新的操作。 首先,我们可以定义一个 `@Query` 注解来执行批量插入或更新操作: ```java @Modifying @Query(value = "INSERT INTO person (id, name) VALUES (:id, :name) ON DUPLICATE KEY UPDATE name=:name", nativeQuery = true) void saveAll(@Param("persons") List<Person> persons); ``` 在上面的 SQL 语句,我们使用了 MySQL 的 `INSERT INTO ... ON DUPLICATE KEY UPDATE` 语法,如果数据库已经存在相同的 `id`,则会更新该记录的 `name` 字段,否则会插入一条新记录。 在 `@Query` 注解,我们使用了 `@Param("persons")` 注解来指定参数名称为 `persons`,这样就可以在 SQL 语句使用 `:persons` 来引用传入的参数了。 接下来,我们可以在调用该方法时,将一组 `Person` 对象传入并执行批量插入或更新操作: ```java List<Person> persons = new ArrayList<>(); persons.add(new Person(1, "Alice")); persons.add(new Person(2, "Bob")); persons.add(new Person(3, "Charlie")); personRepository.saveAll(persons); ``` 在上面的代码,我们创建了一个包含 3 个 `Person` 对象的列表,并将其传入 `personRepository` 的 `saveAll` 方法,该方法使用了上面定义的 `@Query` 注解来执行批量插入或更新操作。 注意,在 `@Query` 注解,我们使用了 `nativeQuery = true` 参数来指定该 SQL 语句是原生 SQL,而不是 JPQL 或 HQL 语句。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值