Rumah > Java > javaTutorial > teks badan

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

DDD
Lepaskan: 2024-10-26 06:38:30
asal
976 orang telah melayarinya

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>
Salin selepas log masuk

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>
Salin selepas log masuk

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>
Salin selepas log masuk

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!

sumber:php.cn
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!