Spring Boot+JPA微服务中数据更新问题(update)

十点数据 1年前 ⋅ 3390 阅读

相关阅读:

基于X-admin2.2的后台管理系统登录实现

Spring Boot整合Java web项目

Spring Boot 踩坑系列之Error resolving template

Spring Boot集成X-admin2.2时,Layui字体图标无法正常显示或乱码问题解决方法

LayUi搜索时,如何只刷新表格内容,其他内容不变?

ZTree工具类汇总,包括:新增、编辑和删除节点,并提交后台

最近在写基于Spring Boot+JPA微服务进行数据更新时,发现始终无法通过**save或者saveAndFlush等均无法对个别字段值进行处理。后来改成@Query**注解完美解决;

Spring Boot在使用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 is java.lang.IllegalArgumentException: Name must not be null or empty!

3)当使用集合作为条件时,可参考此处的ids

全部评论: 0

    我有话说: