Hibernate を介して PostgreSQL 数値配列を Java の数値配列にマッピングしようとすると、例外が発生する可能性があります。これは、次の手順に従って解決できます。
プロジェクトの pom.xml 構成ファイルに次の依存関係を追加します:
<code class="xml"><dependency> <groupId>com.vladmihalcea</groupId> <artifactId>hibernate-types-52</artifactId> <version>${hibernate-types.version}</version> </dependency></code>
配列列のカスタム Hibernate タイプを定義します:
<code class="java">@TypeDefs({ @TypeDef( name = "string-array", typeClass = StringArrayType.class ), @TypeDef( name = "int-array", typeClass = IntArrayType.class ) })</code>
これらのカスタム タイプを使用してエンティティ フィールドを PostgreSQL 配列列にマッピングします:
<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>
配列値を持つエンティティを挿入すると、Hibernate は次のような SQL ステートメントを生成します:
<code class="sql">INSERT INTO event ( version, sensor_names, sensor_values, id ) VALUES ( 0, {"Temperature","Pressure"}, {"12","756"}, 1 )</code>
以上がHibernate を使用して PostgreSQL 配列を Java 配列にマップする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。