温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

如何解决Spring data jpa @Query update的坑

发布时间:2022-02-24 13:38:40 来源:亿速云 阅读:467 作者:小新 栏目:开发技术

小编给大家分享一下如何解决Spring data jpa @Query update的坑,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

    Spring data jpa @Query update的坑

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

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

    可以参考这个例子

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

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

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

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

    Spring data jpa的update操作

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

    1、调用保存实体的方法

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

    2)保存多个实体:repository.save(Iterable<T> 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<String> ids);

    注:

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

    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! 

    以上是“如何解决Spring data jpa @Query update的坑”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI