Spring data jpa @Query update的坑及解决

网友投稿 2560 2022-10-27

Spring data jpa @Query update的坑及解决

Spring data jpa @Query update的坑及解决

目录Springdatajpa@Queryupdate的坑可以参考这个例子Springdatajpa的update操作1、调用保存实体的方法2、@Query注解,自己写JPQL语句

Spring data jpa @Query update的坑

jpa默认只有save(Entity)方法,如果数据库中没有记录就新增,如果数据库中有记录就更新记录。

如果要手动添加update(Entity)方法,

可以参考这个例子

@Modifying

@Query(value = "UPDATE SmallFileEntity s SET s.length = '#{entity.getLength()}' , s.modificationTime = '#{entity.getModeXDaFificationTime()}', s.accessTime = '#{entity.getAccessTime()}' WHERE s.autoId = '#{entity.getAutoId()}' ", nativeQuery = false)

void updateLengthAndModificationTimeAndAccessTime(SmallFileEntity entity);

上例的重点是将EL表达式用单括eXDaF号括起来。

EL表达式中是可以书写java语句的,在@Query注解中,EL表达式可以取到参数列表中的对象。

实在不行的话,就nativeQuery = true。

Spring data jpa的update操作

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

1、调用保存实体的方法

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

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

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

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

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

例:

@Modifying

@Query("update ShopCoupon sc set sc.deleted = true where sc.id in :ids")

public void deleteByIds(@Param(value = "ids") List ids);

注:

1)update或delete时必须使用@Modifying对方法进行注解,才能使得ORM知eXDaF道现在要执行的是写操作

2)有时候不加@Param注解参数,可能会报如下异常:

org.springframework.dao.InvalidDataAccessApiUsageException: Name must not be null or empty!; nested exception i                is Java.lang.IllegalArgumentException: Name must not be null or empty! 

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:白话空间统计二十四:地理加权回归(七)ArcGIS的GWR工具扩展参数说明
下一篇:拥有REST API身份验证的Express和mongodb应用程序的样板
相关文章

 发表评论

暂时没有评论,来抢沙发吧~