淺談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是更據(jù)內(nèi)存中的狀態(tài)更新數(shù)據(jù)的(和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
關鍵點二和四可以叫投影查詢,這種效率更高
【編輯推薦】