web-dev-qa-db-ja.com

PostgreSqlのJSONBデータ型でHibernateを使用することは可能ですか?

Hibernate 5は、デフォルトでPostgreSQL jsonbデータ型をサポートしていません。

Hibernate + Spring JPAのjsonbサポートを実装する方法はありますか?

方法がある場合、Hibernateでjsonbを使用することの長所と短所は何ですか?

8
Aventes

ありがとう Vlad Mihalcea このような機会があります! )

彼は hibernate-types libを作成しました:

<dependency>
    <groupId>com.vladmihalcea</groupId>
    <artifactId>hibernate-types-52</artifactId>
    <version>2.1.1</version>
</dependency> 

hibernateに「json」、「jsonb」およびその他のタイプのサポートを追加します。

@Data
@NoArgsConstructor
@Entity
@Table(name = "parents")
@TypeDefs({
        @TypeDef(name = "string-array", typeClass = StringArrayType.class),
        @TypeDef(name = "int-array", typeClass = IntArrayType.class),
        @TypeDef(name = "json", typeClass = JsonStringType.class),
        @TypeDef(name = "jsonb", typeClass = JsonBinaryType.class)
})
public class Parent implements Serializable {

    @Id
    @GeneratedValue(strategy = SEQUENCE)
    private Integer id;

    @Column(length = 32, nullable = false)
    private String name;

    @Type(type = "jsonb")
    @Column(columnDefinition = "jsonb")
    private List<Child> children;

    @Type(type = "string-array")
    @Column(columnDefinition = "text[]")
    private String[] phones;

    public Parent(String name, List<Child> children, String... phones) {
        this.name = name;
        this.children = children;
        this.phones = phones;
    }
}

@Data
@NoArgsConstructor
@AllArgsConstructor
public class Child implements Serializable {
    private String name;
}

詳細: 12

21
Cepr0

@ Cepr -s答えは正しいですが、いくつかの問題がありますが。 PostgreSQLで使用しようとすると例外が発生していましたorg.hibernate.MappingException: No Dialect mapping for JDBC type: 1111。これを解決する方法は、私の場合、カスタムの休止状態の方言を追加することでした。 これ リソースが役立つ場合があります。

// CustomPostgreSQLDialect.Java
public class CustomPostgreSQLDialect extends PostgreSQL10Dialect {

    public CustomPostgreSQLDialect() {
        super();
        registerHibernateType(Types.OTHER, StringArrayType.class.getName());
        registerHibernateType(Types.OTHER, IntArrayType.class.getName());
        registerHibernateType(Types.OTHER, JsonStringType.class.getName());
        registerHibernateType(Types.OTHER, JsonBinaryType.class.getName());
        registerHibernateType(Types.OTHER, JsonNodeBinaryType.class.getName());
        registerHibernateType(Types.OTHER, JsonNodeStringType.class.getName());
    }
}

-

# application.yml
spring:
  jpa:
    properties:
      hibernate:
        dialect: "com.test.CustomPostgreSQLDialect"
0
GROX13