Hibernate 5は、デフォルトでPostgreSQL jsonb
データ型をサポートしていません。
Hibernate + Spring JPAのjsonb
サポートを実装する方法はありますか?
方法がある場合、Hibernateでjsonb
を使用することの長所と短所は何ですか?
ありがとう 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;
}
@ 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"