JPA: Menukar Keputusan Pertanyaan Asli kepada Kelas POJO
Masalah:
Di JPA, apabila melaksanakan pertanyaan asli, hasilnya biasanya dikembalikan sebagai tatasusunan objek atau senarai tatasusunan. Adakah terdapat cara untuk menukar hasil ini secara terus kepada koleksi kelas Java POJO (Objek Java Lama Biasa) yang mempunyai nama lajur yang sama dengan set hasil?
Penyelesaian:
Menggunakan Entiti Dipeta (JPA 2.0 dan ke atas)
JPA 2.0 dan seterusnya membenarkan pemetaan hasil pertanyaan asli kepada POJO yang dipetakan entiti dalam konteks kegigihan. Untuk mencapai ini, anotasi kelas POJO dengan @Entity dan gunakan pertanyaan asli bernama dengan resultClass ditetapkan ke kelas POJO:
@NamedNativeQuery( name = "nativeSQL", query = "SELECT * FROM Actors", resultClass = Actor.class )
Pemetaan Manual
Untuk kes apabila menggunakan entiti yang dipetakan tidak boleh dilaksanakan, pemetaan manual boleh digunakan. Ini melibatkan mencipta kaedah yang mengambil tatasusunan objek (tuple) sebagai input dan memetakannya ke POJO menggunakan pantulan:
public static <t> T map(Class<t> type, Object[] tuple) { // ... (Reflection code omitted for brevity) }</t></t>
Menggunakan @SqlResultSetMapping (JPA 2.1 dan ke atas)
JPA 2.1 memperkenalkan anotasi @SqlResultSetMapping, yang membenarkan pemetaan tersuai hasil pertanyaan asli kepada POJO. Tentukan pemetaan dalam entiti atau fail orm.xml dan gunakannya dalam pertanyaan asli:
@SqlResultSetMapping( name = "JediResult", classes = { @ConstructorResult( targetClass = Jedi.class, columns = { @ColumnResult(name = "name"), @ColumnResult(name = "age") } ) } )
Query query = em.createNativeQuery("SELECT name,age FROM jedis_table", "JediResult");
Menggunakan Pemetaan XML
Daripada menggunakan anotasi , pemetaan set hasil tersuai boleh ditakrifkan dalam fail orm.xml, membenarkan konfigurasi yang lebih terpusat.
<sql-result-set-mapping name="JediMapping"> <constructor-result target-class="org.answer.model.Jedi"> <column name="name" class="java.lang.String"></column> <column name="age" class="java.lang.Integer"></column> </constructor-result> </sql-result-set-mapping>
Atas ialah kandungan terperinci Bagaimana untuk Menukar Keputusan Pertanyaan Asli kepada POJO dalam JPA?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Artikel ini membincangkan menggunakan Maven dan Gradle untuk Pengurusan Projek Java, membina automasi, dan resolusi pergantungan, membandingkan pendekatan dan strategi pengoptimuman mereka.

Artikel ini membincangkan membuat dan menggunakan perpustakaan Java tersuai (fail balang) dengan pengurusan versi dan pergantungan yang betul, menggunakan alat seperti Maven dan Gradle.

Artikel ini membincangkan pelaksanaan caching pelbagai peringkat di Java menggunakan kafein dan cache jambu untuk meningkatkan prestasi aplikasi. Ia meliputi persediaan, integrasi, dan faedah prestasi, bersama -sama dengan Pengurusan Dasar Konfigurasi dan Pengusiran PRA Terbaik

Artikel ini membincangkan menggunakan JPA untuk pemetaan objek-relasi dengan ciri-ciri canggih seperti caching dan pemuatan malas. Ia meliputi persediaan, pemetaan entiti, dan amalan terbaik untuk mengoptimumkan prestasi sambil menonjolkan potensi perangkap. [159 aksara]

Kelas kelas Java melibatkan pemuatan, menghubungkan, dan memulakan kelas menggunakan sistem hierarki dengan bootstrap, lanjutan, dan pemuat kelas aplikasi. Model delegasi induk memastikan kelas teras dimuatkan dahulu, yang mempengaruhi LOA kelas tersuai


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

mPDF
mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),

Pelayar Peperiksaan Selamat
Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.

ZendStudio 13.5.1 Mac
Persekitaran pembangunan bersepadu PHP yang berkuasa

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Dreamweaver Mac版
Alat pembangunan web visual