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 を使用して数値 PostgreSQL 配列を数値 Java 配列にマップしようとすると、データベース クエリ中に例外が発生しました。

解決策

この問題を解決するには、次の手順に従います:

  1. Hibernate Types 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 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!