Lorsque vous essayez de mapper un tableau numérique PostgreSQL à un tableau numérique en Java via Hibernate, vous pouvez rencontrer une exception. Cela peut être résolu en suivant ces étapes :
Ajoutez la dépendance suivante au fichier de configuration pom.xml de votre projet :
<code class="xml"><dependency> <groupId>com.vladmihalcea</groupId> <artifactId>hibernate-types-52</artifactId> <version>${hibernate-types.version}</version> </dependency></code>
Définissez des types Hibernate personnalisés pour les colonnes du tableau :
<code class="java">@TypeDefs({ @TypeDef( name = "string-array", typeClass = StringArrayType.class ), @TypeDef( name = "int-array", typeClass = IntArrayType.class ) })</code>
Mappez les champs d'entité aux colonnes du tableau PostgreSQL à l'aide de ces types personnalisés :
<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>
Lors de l'insertion d'entités avec des valeurs de tableau, Hibernate générera des instructions SQL similaires à celles-ci :
<code class="sql">INSERT INTO event ( version, sensor_names, sensor_values, id ) VALUES ( 0, {"Temperature","Pressure"}, {"12","756"}, 1 )</code>
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!