您好,登錄后才能下訂單哦!
本篇內容介紹了“Hibernate中HQL查詢需要注意什么”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
一、Hibernate對象的HQL查詢
Sql代碼
select u from User u select u from User u return:List<User>
返回的是裝有持久化對象的List集合 ,持久化對象,在session中,受session生命周期的管理,只要session不關閉,就存在。
二、Hibernate屬性的HQL查詢
Sql代碼
select u.id,u.name ,u.email from User u select u.id,u.name ,u.email from User u return : List<Object[]>
返回的是普通JavaBean對象
1:不占用Hibernate的session緩存,只要被檢索之后,應用程序不在訪問他們,垃圾回收器就會回收。
2:Hibernate不會對他們進行同步修改,因為Hibernate是更據內存中的狀態更新數據的(和DB交互)
三、Hibernate自定義的HQL查詢
Sql代碼
select new com.lovo.vo.User(u.name,u.age,c.email) from User u left join Conter c select new com.lovo.vo.User(u.name,u.age,c.email) from User u left join Conter c
這種是你一定要返回一個對象是,而且這些屬性來自不同的表,
需要注意的是:new的對象一定要是:全路徑
四、其他
select u.name from User u
返回的是List
關鍵點二和四可以叫投影查詢,這種效率更高
“Hibernate中HQL查詢需要注意什么”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。