Jadual Kandungan
Memetakan Tatasusunan PostgreSQL ke Tatasusunan Java dengan Hibernate
Masalah
Penyelesaian
Contoh
Rumah Java javaTutorial Bagaimana untuk Memetakan Array PostgreSQL ke Array Java dengan Hibernate?

Bagaimana untuk Memetakan Array PostgreSQL ke Array Java dengan Hibernate?

Oct 25, 2024 am 07:07 AM

How to Map PostgreSQL Arrays to Java Arrays with Hibernate?

Memetakan Tatasusunan PostgreSQL ke Tatasusunan Java dengan Hibernate

Masalah

Mencuba memetakan tatasusunan PostgreSQL berangka ke tatasusunan Java berangka menggunakan hasil Hibernate dalam pengecualian semasa pertanyaan pangkalan data.

Penyelesaian

Untuk menyelesaikan isu ini, ikut langkah berikut:

  1. Tambah Ketergantungan Maven Jenis Hibernate:

1

2

3

4

5

<code class="xml">&lt;dependency&gt;

    &lt;groupId&gt;com.vladmihalcea&lt;/groupId&gt;

    &lt;artifactId&gt;hibernate-types-52&lt;/artifactId&gt;

    &lt;version&gt;${hibernate-types.version}&lt;/version&gt;

&lt;/dependency&gt;</code>

Salin selepas log masuk
  1. Tentukan Takrifan Jenis Hibernate:

Dalam kelas Java anda, nyatakan jenis Hibernate tersuai yang akan anda gunakan untuk memetakan tatasusunan:

1

2

3

4

5

6

7

<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>

Salin selepas log masuk
  1. Buat Jenis Hibernate Tersuai (Pilihan):

Kelas StringArrayType dan IntArrayType tidak terbina dalam; anda perlu menciptanya seperti berikut:

1

2

3

4

5

6

7

8

<code class="java">@TypeDef(

    name = "string-array",

    typeClass = StringArrayType.class

)

@TypeDef(

    name = "int-array",

    typeClass = IntArrayType.class

)</code>

Salin selepas log masuk
  1. Pengujian:

Apabila entiti berterusan dengan nilai tatasusunan, Hibernate akan menjana pernyataan SQL yang peta tatasusunan dengan betul.

Contoh

Andaikan struktur jadual berikut:

1

2

3

4

5

6

7

<code class="sql">CREATE TABLE event (

    id int8 not null,

    version int4,

    sensor_names text[],

    sensor_values integer[],

    primary key (id)

);</code>

Salin selepas log masuk

Anda boleh memetakannya ke kelas Java berikut:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

<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>

Salin selepas log masuk

Apabila memasukkan entiti dengan nilai tatasusunan, Hibernate akan menjana pernyataan SQL seperti:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

<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>

Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimana untuk Memetakan Array PostgreSQL ke Array Java dengan Hibernate?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Tag artikel panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Rangka Kerja 4 JavaScript teratas pada tahun 2025: React, Angular, Vue, Svelte Rangka Kerja 4 JavaScript teratas pada tahun 2025: React, Angular, Vue, Svelte Mar 07, 2025 pm 06:09 PM

Rangka Kerja 4 JavaScript teratas pada tahun 2025: React, Angular, Vue, Svelte

Bagaimanakah mekanisme kelas muatan Java berfungsi, termasuk kelas yang berbeza dan model delegasi mereka? Bagaimanakah mekanisme kelas muatan Java berfungsi, termasuk kelas yang berbeza dan model delegasi mereka? Mar 17, 2025 pm 05:35 PM

Bagaimanakah mekanisme kelas muatan Java berfungsi, termasuk kelas yang berbeza dan model delegasi mereka?

Spring Boot Snakeyaml 2.0 CVE-2022-1471 Isu Tetap Spring Boot Snakeyaml 2.0 CVE-2022-1471 Isu Tetap Mar 07, 2025 pm 05:52 PM

Spring Boot Snakeyaml 2.0 CVE-2022-1471 Isu Tetap

Iceberg: Masa Depan Jadual Data Tasik Iceberg: Masa Depan Jadual Data Tasik Mar 07, 2025 pm 06:31 PM

Iceberg: Masa Depan Jadual Data Tasik

Bagaimanakah saya boleh menggunakan JPA (Java Constence API) untuk pemetaan objek-objek dengan ciri-ciri canggih seperti caching dan malas malas? Bagaimanakah saya boleh menggunakan JPA (Java Constence API) untuk pemetaan objek-objek dengan ciri-ciri canggih seperti caching dan malas malas? Mar 17, 2025 pm 05:43 PM

Bagaimanakah saya boleh menggunakan JPA (Java Constence API) untuk pemetaan objek-objek dengan ciri-ciri canggih seperti caching dan malas malas?

Node.js 20: Peningkatan Prestasi Utama dan Ciri -ciri Baru Node.js 20: Peningkatan Prestasi Utama dan Ciri -ciri Baru Mar 07, 2025 pm 06:12 PM

Node.js 20: Peningkatan Prestasi Utama dan Ciri -ciri Baru

Bagaimanakah saya melaksanakan caching pelbagai peringkat dalam aplikasi java menggunakan perpustakaan seperti kafein atau cache jambu? Bagaimanakah saya melaksanakan caching pelbagai peringkat dalam aplikasi java menggunakan perpustakaan seperti kafein atau cache jambu? Mar 17, 2025 pm 05:44 PM

Bagaimanakah saya melaksanakan caching pelbagai peringkat dalam aplikasi java menggunakan perpustakaan seperti kafein atau cache jambu?

Bagaimanakah saya menggunakan Maven atau Gradle untuk Pengurusan Projek Java Lanjutan, Membina Automasi, dan Resolusi Ketergantungan? Bagaimanakah saya menggunakan Maven atau Gradle untuk Pengurusan Projek Java Lanjutan, Membina Automasi, dan Resolusi Ketergantungan? Mar 17, 2025 pm 05:46 PM

Bagaimanakah saya menggunakan Maven atau Gradle untuk Pengurusan Projek Java Lanjutan, Membina Automasi, dan Resolusi Ketergantungan?

See all articles