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
- public class Problem {
- private int pid;
- private int score;
- private int timeLimit;
- private int memoryLimit;
- private int totalAccept;
- private int totalSubmission;
- private int unSee;
- private String title;
- private String description;
- private String input;
- private String output;
- public Problem(int pid, int score,String title, int totalAccept, int totalSubmission,
- int unSee) {
- super();
- this.pid = pid;
- this.score = score;
- this.totalAccept = totalAccept;
- this.totalSubmission = totalSubmission;
- this.unSee = unSee;
- this.title = title;
- }
- //省略getter 和 setter
- }
- Query query=session.createQuery("select new Problem(pid,score,title,totalAccept,totalSubmission,unSee) from Problem order by pid");
- //query.setFirstResult(firstResult); //分頁函數
- //query.setMaxResults(maxResutl);
- List<Problem> problems=query.list();//返回的還是Problem對象