【问题标题】:Versioning JSON objects in PostgreSQL database with Hibernate使用 Hibernate 对 PostgreSQL 数据库中的 JSON 对象进行版本控制
【发布时间】:2021-05-25 14:25:17
【问题描述】:

我想在数据库中存储 JSON 对象。

我希望对我的对象进行版本控制,并在读取时将它们延迟转换为最新版本。

我正在使用带有 JPA 的 Spring Boot 2.4+。

我已经配置hibernate-types-52 来做映射,一切正常。

现在,我希望能够读取数据库中的 ObjectV1,并将其转换为在我的 JPA 实体中定义的 ObjectV2

我已经用 jOOQ 成功地做到了这一点,所以我想用 JPA 做同样的事情。

我在哪里可以截取反序列化的对象以使用自制代码将其转换为最新版本?

我已经配置了对象映射器,以便在 @class 字段中存储在 json 中的类的简单名称,以及存储在数据库中的所有对象都实现一个通用接口,因此多态性应该可以与 Jackson 一起正常工作.

我可以在 JPA 实体的 getter 中进行映射,但我正在寻找更透明的解决方案。

【问题讨论】:

    标签: postgresql hibernate jpa jsonb hibernate-types


    【解决方案1】:

    不确定您必须配置什么,但您可以通过设置系统属性hibernate.types.jackson.object.mapper 来覆盖使用的对象映射器。下面是访问对象映射器的代码:https://github.com/vladmihalcea/hibernate-types/blob/master/hibernate-types-52/src/main/java/com/vladmihalcea/hibernate/type/util/Configuration.java#L137

    【讨论】:

    • 我已经配置了对象映射器。是的,我可以在那里解决问题,但我认为可能有一个 JPA 特定层来拦截它。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2015-01-31
    • 2019-08-10
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-03-22
    • 2010-11-20
    相关资源
    最近更新 更多