将PostgreSQL JSONB类型与HibernateReact性一起使用

w41d8nur  于 2022-11-14  发布在  PostgreSQL
关注(0)|答案(1)|浏览(153)

我正在将我的Quarkus项目从经典的Hibernate ORM迁移到Hibernate Active,我遇到了一个JSONB字段Map的问题。
以下是实体:

@Entity
@TypeDef(name = JsonTypes.JSON_BIN, typeClass = JsonBinaryType::class)
class MyEntity {
    @Id
    @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "myEntityIdGenerator")
    @SequenceGenerator(name = "myEntityIdGenerator", sequenceName = "my_entity_id_seq", allocationSize = 10)
    var id: Long? = null

    // Usage of a plain JsonNode instead of a mapped class is intentional, 
    // as the app receives a request with raw JSON data and should store it without any processing
    @Type(type = JsonTypes.JSON_BIN)
    @NotNull
    lateinit var jsonData: JsonNode
}

该项目具有处理JSON类型的io.quarkiverse.hibernatetypes:quarkus-hibernate-types:0.2.0依赖项。
这段代码可以很好地阻止Hibernate API,但当尝试使用HibernateReact来持久化MyEntity时,我得到了以下异常:

io.vertx.core.impl.NoStackTraceThrowable: Parameter at position[1] with class = [com.fasterxml.jackson.databind.node.ObjectNode] and value = [{"field1":"some value"}] can not be coerced to the expected class = [java.lang.Object] for encoding.

这是一个错误,还是在使用HibernateReact性时应该以不同的方式处理自定义类型?

5tmbdcev

5tmbdcev1#

休眠类型与休眠React性不兼容。
但是您有三个选项来Map一个Json和HibenrateReact性:
1.使用io.vertx.core.json.JsonObject
1.将其Map为字符串并使用转换器
1.创建UserType

1.JsonObject

io.vertx.core.json.JsonObject示例:

@Entity
    private static class EntityWithJson {

        ...

        private JsonObject jsonObj;

...
}

您可以在存储库中看到一个正在运行的示例:JsonTypeTest

2.使用转换器

使用转换器的示例:

class EntityWithJson {

        @Column(columnDefinition = "json")
        @Convert(converter = StringToJson.class)
        private String json;
...
}

@Converter
public class StringToJson implements AttributeConverter<String, JsonObject> {

    @Override
    public JsonObject convertToDatabaseColumn(String string) {
        if (string == null) {
            return null;
        }
        return new JsonObject(string);
    }

    @Override
    public String convertToEntityAttribute(JsonObject dbData) {

        if (dbData == null) {
            return null;
        }
        return dbData.encodePrettily();
    }
}

您可以在存储库中看到一个正在运行的示例:JsonTypeTest

3.用户类型

class EntityWithJson {

        @Type(type="org.example.Json")
        @Column(columnDefinition = "json")
        private JsonObject jsonObj;

}

package org.example

public class Json implements UserType {

   // ... Implementation left out for brevity
}

您可以在存储库中看到一个正在运行的示例:UserJsonTypeTest

相关问题