Rumah >Java >javaTutorial >Bagaimana untuk Memetakan Lajur JSON dalam PostgreSQL untuk Hibernate Entiti Hartanah?
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.
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!