Hibernate を使用して PostgreSQL の数値配列列を Java の数値配列フィールドにマップしようとすると、例外が発生する可能性があります。
この問題を解決するには、次の手順に従います。
1. Maven 依存関係の追加
プロジェクトの pom.xml ファイルに、次の Hibernate Types Maven 依存関係を追加します。
<code class="xml"><dependency> <groupId>com.vladmihalcea</groupId> <artifactId>hibernate-types-52</artifactId> <version>${hibernate-types.version}</version> </dependency></code>
2. Hibernate タイプの構成
Hibernate 構成で、次の TypeDefs を追加して Hibernate タイプを有効にします:
<code class="java">@TypeDefs({ @TypeDef( name = "string-array", typeClass = StringArrayType.class ), @TypeDef( name = "int-array", typeClass = IntArrayType.class ) })</code>
3. Hibernate 型の定義 (オプション)
StringArrayType クラスと IntArrayType クラスが定義されていない場合は、それらをスーパークラスに含めることができます:
<code class="java">@MappedSuperclass public class BaseEntity { @Id private Long id; @Type(type = "string-array") private String[] stringArray; @Type(type = "int-array") private int[] intArray; // Getters and setters omitted for brevity }</code>
4.エンティティのマッピング
マッピングの例:
<code class="java">@Entity(name = "Event") @Table(name = "event") public class Event extends BaseEntity { @Type(type = "string-array") private String[] sensorNames; @Type(type = "int-array") private int[] sensorValues; // Getters and setters omitted for brevity }</code>
クエリの例
<code class="java">Event event = entityManager.find(Event.class, 1L); // Accessing the mapped array properties for (String sensorName : event.getSensorNames()) { System.out.println(sensorName); } for (int sensorValue : event.getSensorValues()) { System.out.println(sensorValue); }</code>
以上がHibernate を使用して PostgreSQL 配列を Java 配列にマップするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。