Hibernate 返回結果list對象

在hibernate中,用hql語句查詢實體類,採用list方法的返回結果爲一個List,該List中封裝的對象分爲以下三種情況:
1.查詢全部字段的情況下,如"from 實體類",list中封裝的對象爲實體類本身,各屬性都將得到填充。
2.只查詢一個字段,默認情況下,list中封裝的是Object對象。
3.查詢兩個或兩個以上的字段,默認情況下,list中封裝的是Object[],長度與所查詢的字段數一致。

對於後兩種情況,用標籤遍歷時不太方便,因爲無法直接轉換成實體類的對象。比較簡單的解決方法是:

の:在hql中使用select new 包名.類名(屬性1,屬性2……) from 實體類,同時在實體類中添加帶參的構造方法,參數的個數和順序與(屬性1,屬性2……) 保持一致,這樣我們得到的list中存放的依然是實體類的對象,所查詢到的屬性得到了填充,使用起來更爲方便。

  の:hql查詢多表部分字段,select new 包名.表1實體類名(表1.屬性1,表2.屬性2……) from 表1實體類,表2實體類 where 表1.ID=表2.ID(即相關聯的字段),同時在要返回的表1實體類中添加表2的屬性和帶參的構造方法,參數的個數和順序與(表1.屬性1,表2.屬性 2……) 保持一致

例如要查詢Problem 中的pid,score,title,totalAccept,totalSubmission,unSee

  1. public class Problem {  
  2.     private int pid;  
  3.     private int score;  
  4.     private int timeLimit;  
  5.     private int memoryLimit;  
  6.     private int totalAccept;  
  7.     private int totalSubmission;  
  8.     private int unSee;  
  9.     private String title;  
  10.     private String description;  
  11.     private String input;  
  12.     private String output;  
  13.       
  14.     public Problem(int pid, int score,String title, int totalAccept, int totalSubmission,  
  15.              int unSee) {  
  16.         super();  
  17.         this.pid = pid;  
  18.         this.score = score;  
  19.         this.totalAccept = totalAccept;  
  20.         this.totalSubmission = totalSubmission;  
  21.         this.unSee = unSee;  
  22.         this.title = title;  
  23.     }  
  24.     //省略getter 和 setter   
  25. }  
查詢語句如下
  1.       Query query=session.createQuery("select new Problem(pid,score,title,totalAccept,totalSubmission,unSee) from Problem order by pid");  
  2.         //query.setFirstResult(firstResult); //分頁函數   
  3.         //query.setMaxResults(maxResutl);   
  4.       
  5.         List<Problem> problems=query.list();//返回的還是Problem對象
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章