1. 程式人生 > >Hibernate中的Query介面

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);
        }

其實下邊還有第三條和第四條資料,沒有截下來
這裡寫圖片描述

這裡寫圖片描述