Rumah >Java >javaTutorial >Bagaimana untuk Memetakan Lajur JSON dalam PostgreSQL untuk Hibernate Entiti Hartanah?

Bagaimana untuk Memetakan Lajur JSON dalam PostgreSQL untuk Hibernate Entiti Hartanah?

DDD
DDDasal
2024-10-26 06:38:301076semak imbas

How to Map JSON Columns in PostgreSQL to Hibernate Entity Properties?

Memetakan Lajur JSON dalam PostgreSQL kepada Sifat Entiti Hibernate

Masalah: Memetakan Lajur JSON kepada Entiti Hibernate

Memetakan data JSON yang disimpan dalam entiti PostgreSQL hartanah boleh mencabar. Percubaan untuk memetakan lajur ke medan Rentetan dalam entiti menimbulkan pengecualian semasa penyimpanan entiti, menunjukkan ketidakupayaan untuk menukar aksara yang berbeza-beza (rentetan) kepada JSON.

Penyelesaian: Menentukan Jenis Pengguna Tersuai

Untuk memetakan lajur JSON dengan berkesan kepada entiti Hibernate, jenis pengguna tersuai mesti ditentukan. Jenis ini menterjemah antara nilai String dan jenis data JSON yang digunakan dalam pangkalan data.

1. Memperluas Dialek PostgreSQL:

Melanjutkan dialek PostgreSQL lalai untuk mengenali jenis "json":

<code class="java">public class JsonPostgreSQLDialect extends PostgreSQL9Dialect {

    public JsonPostgreSQLDialect() {
        super();
        this.registerColumnType(Types.JAVA_OBJECT, "json");
    }
}</code>

2. Melaksanakan Jenis Pengguna:

Laksanakan antara muka org.hibernate.usertype.UserType untuk mentakrifkan pemetaan tersuai:

<code class="java">public class StringJsonUserType implements UserType {

    // ... implementation of required methods ...
}</code>

3. Menganotasi Entiti dan Harta:

Tambahkan anotasi berikut pada pengisytiharan kelas entiti dan sifat yang dipetakan JSON:

<code class="java">@TypeDefs({@TypeDef(name = "StringJsonObject", typeClass = StringJsonUserType.class)})
...
@Type(type = "StringJsonObject")
public String getJsonPayload() { ... }</code>

Sampel Projek:

Rujuk projek GitHub untuk contoh pelaksanaan lengkap: https://github.com/timfulmer/hibernate-postgres-jsontype

Atas ialah kandungan terperinci Bagaimana untuk Memetakan Lajur JSON dalam PostgreSQL untuk Hibernate Entiti Hartanah?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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