Hibernate中的Query介面
一.Hibernate框架的API
學習每一個知識點,都要知道這個知識點的源頭是在哪裡,只有看最原始的內容,才能讓我們理解的更深.對於java來說最原始的就是他的api.
1.框架的API在哪裡看?
首先在官網下載這個壓縮包,在裡面找到
hibernate-release5.0.7.Final\documentation\javadocs\index.html
https://sourceforge.net/projects/hibernate/files/hibernate-orm/5.2.9.Final/hibernate-release-5.2.9.Final.zip/download
二.Query介面
1.當中的一些方法
list();返回查詢結果,並把查詢結果轉換成list物件;
iterate()
setString(int position,String value);設定HQL中的“?”的值,其中position代表“?”在HQL中的位置,value是要為“?”設定的值
setString(String paraName,String value);設定HQL中“:”後所跟變數的值;其中paraName代表HQL中“:”後邊的變數名,value是該變數的值:
setInteger(int position, int val)
setInteger(String name, int val)
setParameter()方法可以代替上面的幾個setxxx方法
三.這些方法的使用
String hql = "from User where age > ?";
Query query = session.createQuery(hql);
query.setInteger(0, 25);
List<User> list = query.list();
for (User user : list) {
System.out.println(user);
}
String hql = "from User where age > :age and name = :name" ;
Query query = session.createQuery(hql);
query.setInteger("age", 20);
query.setString("name", "張三");
List<User> list = query.list();
for (User user : list) {
System.out.println(user);
}
四.list和iterator方法的區別
list是一次性的獲取到查詢的所有資料,只從資料庫查詢一次
而Iterator是一次獲取一條資料,每次都會從資料庫中重新查詢
String hql = "from User";
Query query = session.createQuery(hql);
Iterator<User> iterate = query.iterate();
while (iterate.hasNext()) {
User user = iterate.next();
System.out.println(user);
}
其實下邊還有第三條和第四條資料,沒有截下來