首頁 > Java > java教程 > 主體

如何使用 Hibernate 將 PostgreSQL 陣列對應到 Java 陣列?

Susan Sarandon
發布: 2024-10-25 07:07:28
原創
109 人瀏覽過

How to Map PostgreSQL Arrays to Java Arrays with Hibernate?

使用Hibernate 將PostgreSQL 數組映射到Java 數組

問題

嘗試使用Hibernate 將數字組查詢資料庫導致數字組數組期間出現異常。

解決方案

要解決此問題,請按照以下步驟操作:

  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中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!