Hibernate を使用して数値 PostgreSQL 配列を数値 Java 配列にマップしようとすると、データベース クエリ中に例外が発生しました。
この問題を解決するには、次の手順に従います:
<code class="xml"><dependency> <groupId>com.vladmihalcea</groupId> <artifactId>hibernate-types-52</artifactId> <version>${hibernate-types.version}</version> </dependency></code>
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>
StringArrayType クラスと IntArrayType クラスは組み込みではありません。次のように作成する必要があります:
<code class="java">@TypeDef( name = "string-array", typeClass = StringArrayType.class ) @TypeDef( name = "int-array", typeClass = IntArrayType.class )</code>
配列値を持つエンティティを永続化する場合、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 サイトの他の関連記事を参照してください。