SpringBoot+JPA微服务中数据更新问题(update)
相关阅读:
基于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")publicvoiddeleteByIds(@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
以上是 SpringBoot+JPA微服务中数据更新问题(update) 的全部内容, 来源链接: utcz.com/z/517176.html