JPA:將本機查詢結果轉換為POJO 類
問題:
在JPA 中,執行本機查詢時,結果通常會以物件陣列或陣列清單傳回。有沒有辦法直接將此結果轉換為與結果集具有相同列名的 Java POJO(普通舊 Java 物件)類別的集合?
解決方案:
使用映射實體(JPA 2.0 和上面)
JPA 2.0 以上)
@NamedNativeQuery( name = "nativeSQL", query = "SELECT * FROM Actors", resultClass = Actor.class )
JPA 2.0 以上版本允許將本及以上版本允許將本及以上版本允許將本及以上版本允許將本及以上版本允許將本及以上版本允許將本及以上版本允許將本及以上版本允許將本及以上版本允許將本及以上版本允許將本及以上版本允許將本及以上版本允許將本及以上版本允許將本及以上版本允許將本及以上版本允許將本以上版本機器查詢結果對應到持久化上下文中映射實體的POJO。若要達成此目的,請使用@Entity 註解POJO 類,並使用命名的本機查詢,並將resultClass 設定為POJO 類別:
手動對映
public static <t> T map(Class<t> type, Object[] tuple) { // ... (Reflection code omitted for brevity) }</t></t>
手動對映
對於情況如果使用映射實體不可行,則可以使用手動映射。這涉及創建一個方法,該方法將物件數組(元組)作為輸入,並使用反射將其映射到POJO:
@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");
使用@SqlResultSetMapping(JPA 2.1 及更高版本)
JPA 2.1 引入了@SqlResultSetMapping註解,它允許原生查詢的自訂映射結果到 POJO。在實體或orm.xml 檔案中定義映射並在本機查詢中使用它:<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>使用XML 映射而不是使用註釋,可以在orm.xml 檔案中定義自訂結果集映射,從而實現更集中的配置。
以上是如何將本機查詢結果轉換為 JPA 中的 POJO?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

JVM'SperformanceIsCompetitiveWithOtherRuntimes,operingabalanceOfspeed,安全性和生產性。 1)JVMUSESJITCOMPILATIONFORDYNAMICOPTIMIZAIZATIONS.2)c提供NativePernativePerformanceButlanceButlactsjvm'ssafetyFeatures.3)

JavaachievesPlatFormIndependencEthroughTheJavavIrtualMachine(JVM),允許CodeTorunonAnyPlatFormWithAjvm.1)codeisscompiledIntobytecode,notmachine-specificodificcode.2)bytecodeisisteredbytheybytheybytheybythejvm,enablingcross-platerssectectectectectross-eenablingcrossectectectectectection.2)

TheJVMisanabstractcomputingmachinecrucialforrunningJavaprogramsduetoitsplatform-independentarchitecture.Itincludes:1)ClassLoaderforloadingclasses,2)RuntimeDataAreafordatastorage,3)ExecutionEnginewithInterpreter,JITCompiler,andGarbageCollectorforbytec

JVMhasacloserelationshipwiththeOSasittranslatesJavabytecodeintomachine-specificinstructions,managesmemory,andhandlesgarbagecollection.ThisrelationshipallowsJavatorunonvariousOSenvironments,butitalsopresentschallengeslikedifferentJVMbehaviorsandOS-spe

Java實現“一次編寫,到處運行”通過編譯成字節碼並在Java虛擬機(JVM)上運行。 1)編寫Java代碼並編譯成字節碼。 2)字節碼在任何安裝了JVM的平台上運行。 3)使用Java原生接口(JNI)處理平台特定功能。儘管存在挑戰,如JVM一致性和平台特定庫的使用,但WORA大大提高了開發效率和部署靈活性。

JavaachievesPlatFormIndependencethroughTheJavavIrtualMachine(JVM),允許Codetorunondifferentoperatingsystemsswithoutmodification.thejvmcompilesjavacodeintoplatform-interploplatform-interpectentbybyteentbytybyteentbybytecode,whatittheninternterninterpretsandectectececutesoneonthepecificos,atrafficteyos,Afferctinginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginginging

JavaispoperfulduetoitsplatFormitiondence,對象與偏見,RichstandardLibrary,PerformanceCapabilities和StrongsecurityFeatures.1)Platform-dimplighandependectionceallowsenceallowsenceallowsenceallowsencationSapplicationStornanyDevicesupportingJava.2)

Java的頂級功能包括:1)面向對象編程,支持多態性,提升代碼的靈活性和可維護性;2)異常處理機制,通過try-catch-finally塊提高代碼的魯棒性;3)垃圾回收,簡化內存管理;4)泛型,增強類型安全性;5)ambda表達式和函數式編程,使代碼更簡潔和表達性強;6)豐富的標準庫,提供優化過的數據結構和算法。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3漢化版
中文版,非常好用

WebStorm Mac版
好用的JavaScript開發工具

禪工作室 13.0.1
強大的PHP整合開發環境

SublimeText3 Linux新版
SublimeText3 Linux最新版

Dreamweaver CS6
視覺化網頁開發工具