首页  >  文章  >  Java  >  如何使用 Hibernate 将 PostgreSQL 数组映射到 Java 数组?

如何使用 Hibernate 将 PostgreSQL 数组映射到 Java 数组?

Susan Sarandon
Susan Sarandon原创
2024-10-25 07:07:28111浏览

How to Map PostgreSQL Arrays to Java Arrays with Hibernate?

使用 Hibernate 将 PostgreSQL 数组映射到 Java 数组

问题

尝试使用 Hibernate 将数字 PostgreSQL 数组映射到数字 Java 数组会导致数据库查询期间出现异常。

解决方案

要解决此问题,请按照以下步骤操作:

  1. 添加 Hibernate 类型 Maven 依赖项:
<code class="xml"><dependency>
    <groupId>com.vladmihalcea</groupId>
    <artifactId>hibernate-types-52</artifactId>
    <version>${hibernate-types.version}</version>
</dependency></code>
  1. 定义 Hibernate 类型定义:

在 Java 类中,指定将用于映射的自定义 Hibernate 类型数组:

<code class="java">@Type(type = "string-array")
@Column(name = "sensor_names", columnDefinition = "text[]")
private String[] sensorNames;

@Type(type = "int-array")
@Column(name = "sensor_values", columnDefinition = "integer[]")
private int[] sensorValues;</code>
  1. 创建自定义 Hibernate 类型(可选):

StringArrayType 和 IntArrayType 类不是内置的;您需要按如下方式创建它们:

<code class="java">@TypeDef(
    name = "string-array",
    typeClass = StringArrayType.class
)
@TypeDef(
    name = "int-array",
    typeClass = IntArrayType.class
)</code>
  1. 测试:

当持久化具有数组值的实体时,Hibernate 将生成以下 SQL 语句:正确映射数组。

示例

假设以下表结构:

<code class="sql">CREATE TABLE event (
    id int8 not null,
    version int4,
    sensor_names text[],
    sensor_values integer[],
    primary key (id)
);</code>

您可以将其映射到以下 Java 类:

<code class="java">@Entity(name = "Event")
@Table(name = "event")
public static class Event extends BaseEntity {

    @Type(type = "string-array")
    @Column(name = "sensor_names", columnDefinition = "text[]")
    private String[] sensorNames;

    @Type(type = "int-array")
    @Column(name = "sensor_values", columnDefinition = "integer[]")
    private int[] sensorValues;

    //Getters and setters omitted for brevity
}</code>

当插入具有数组值的实体时,Hibernate 将生成如下 SQL 语句:

<code class="sql">INSERT INTO event (
    version,
    sensor_names,
    sensor_values,
    id
)
VALUES (
    0,
    {NULL},
    {NULL},
    0
);

INSERT INTO event (
    version,
    sensor_names,
    sensor_values,
    id
)
VALUES (
    0,
    {"Temperature","Pressure"},
    {"12","756"},
    1
);</code>

以上是如何使用 Hibernate 将 PostgreSQL 数组映射到 Java 数组?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn