SpringBoot中JPA更新时部分字段无效怎么解决

发布时间:2023-05-08 15:15:28 作者:iii
来源:亿速云 阅读:128

这篇“SpringBoot中JPA更新时部分字段无效怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“SpringBoot中JPA更新时部分字段无效怎么解决”文章吧。

相关源码

实体类定义

@Table(name = "t_workspace")
@Entity
@DynamicInsert
@DynamicUpdate
@org.hibernate.annotations.Table(appliesTo = "t_workspace", comment = "工作空间表")
public class WorkSpaceEntity extends BaseEntity {


    @Column(columnDefinition = "TEXT COMMENT '模型图结构' ")
    private String mxGraphModel;

    @Convert(converter = ModelDataConver.class)
    @Column(columnDefinition = "mediumtext comment '存储模型数据集'")
    private ModelData modelData;
}

相关业务语句如下,用于更新mxGraphModelmodelData

workSpace.setMxGraphModel(newEntity.getMxGraphModel());
workSpace.setModelData(newEntity.getModelData());

但实际执行的SQL语句如下

Hibernate: update t_workspace set wupdated_at=?, wmx_graph_model=? where wid=?

@DynamicUpdate适用属性

如上所示,使用注解@DynamicUpdate自动更新,但是该注解只能自动更新实体属性。而实体属性是指JPA认定的基本数据类型以及关联类型属性。另外,如果实体类中存在一些计算属性或者需要在插入或更新时设置默认值的属性,那么这些属性可能会被忽略,导致出现数据不一致的情况。

计算属性

实体类中的计算属性指的是,这些属性的值是根据其他属性计算得出的,而不是从数据库中直接获取的。例如,订单实体类中的总金额属性,可能是根据订单项的数量和单价计算得出的,而不是从数据库中直接获取的。

插入或更新时设置默认值

需要在插入或更新时设置默认值的属性,指的是这些属性在插入或更新时需要设置默认值,例如创建时间、更新时间、是否删除等属性。

这些属性有以下特点:

JPA基本数据类型

基本类型指的是 Java 中的基本数据类型,包括 byte、short、int、long、float、double、char、boolean 等。在 JPA 中,除了基本数据类型之外,还包括一些 Java 类型,例如 String、java.util.Date、java.sql.Date、java.sql.Time、java.sql.Timestamp 等。

关联类型属性

通过@OneToOne、@OneToMany、@ManyToOne、@ManyToMany注解的属性

综上

ModelData属于自定义类,作为JPA的三等公民,没有被优待的权利。而JPA中对象即表的概念展现得淋漓尽致。

以上就是关于“SpringBoot中JPA更新时部分字段无效怎么解决”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注亿速云行业资讯频道。

推荐阅读:
  1. SpringBoot2如何实现集成JPA持久层框架、简化数据库操作
  2. 如何通过JPA + Eclipse连接SAP的HANA数据库

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

jpa springboot

上一篇:MySQL数据库和Redis缓存一致性的更新策略是什么

下一篇:k8s NetworkPolicy网络策略怎么使用

相关阅读

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

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