日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

(2)hibernate HQL命名查询和Query接口的分页查询

發布時間:2024/1/23 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 (2)hibernate HQL命名查询和Query接口的分页查询 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一 ?hql命名查詢

hibernate中對動態查詢參數綁定提供了豐富的支持,那么什么是查詢參數動態綁定呢?其實如果我們熟悉傳統JDBC編程的話,我們就不難理解查詢參數動態綁定,如下代碼傳統JDBC的參數綁定:?

PrepareStatement pre=connection.prepare(“select * from User where user.name=?”);?
pre.setString(1,”zhaoxin”);?
ResultSet rs=pre.executeQuery();?

Hibernate中也提供了類似這種的查詢參數綁定功能,而且在Hibernate中對這個功能還提供了比傳統JDBC操作豐富的多的特性,在Hibernate中共存在4種參數綁定的方式,下面我們將分別介紹:?

A、 按參數名稱綁定:?

HQL語句中定義命名參數要用”:”開頭,形式如下:?
Query query=session.createQuery(“from User user where user.name=:customername and user:customerage=:age ”);?
query.setString(“customername”,name);?
query.setInteger(“customerage”,age);?

上面代碼中用:customername:customerage分別定義了命名參數customernamecustomerage,然后用Query接口的setXXX()方法設定名參數值,setXXX()方法包含兩個參數,分別是命名參數名稱和命名參數實際值。?

B、 按參數位置邦定:?

HQL查詢語句中用”?”來定義參數位置,形式如下:?
Query query=session.createQuery(“from User user where user.name=? and user.age =? ”);?
query.setString(0,name);?
query.setInteger(1,age);?

同樣使用setXXX()方法設定綁定參數,只不過這時setXXX()方法的第一個參數代表邦定參數在HQL語句中出現的位置編號(由0開始編號),第二個參數仍然代表參數實際值。?

注:在實際開發中,提倡使用按名稱邦定命名參數,因為這不但可以提供非常好的程序可讀性,而且也提高了程序的易維護性,因為當查詢參數的位置發生改變時,按名稱邦定名參數的方式中是不需要調整程序代碼的。?

CsetParameter()方法:?

HibernateHQL查詢中可以通過setParameter()方法邦定任意類型的參數,如下代碼:?
String hql=”from User user where user.name=:customername ”;?
Query query=session.createQuery(hql);?
query.setParameter(“customername”,name,Hibernate.STRING);?

如上面代碼所示,setParameter()方法包含三個參數,分別是命名參數名稱,命名參數實際值,以及命名參數映射類型。對于某些參數類型setParameter()方法可以更具參數值的Java類型,猜測出對應的映射類型,因此這時不需要顯示寫出映射類型,像上面的例子,可以直接這樣寫:?

query.setParameter(“customername”,name);但是對于一些類型就必須寫明映射類型,比如java.util.Date類型,因為它會對應Hibernate的多種映射類型,比如Hibernate.DATA或者Hibernate.TIMESTAMP

DsetProperties()方法:?

Hibernate中可以使用setProperties()方法,將命名參數與一個對象的屬性值綁定在一起,如下程序代碼:?

Customer customer=new Customer();?
customer.setName(“pansl”);?
customer.setAge(80);?
Query query=session.createQuery(“from Customer c where c.name=:name and c.age=:age ”);?
query.setProperties(customer);?

setProperties()方法會自動將customer對象實例的屬性值匹配到命名參數上,但是要求命名參數名稱必須要與實體對象相應的屬性同名。?

這里還有一個特殊的setEntity()方法,它會把命名參數與一個持久化對象相關聯,如下面代碼所示:?

Customer customer=(Customer)session.load(Customer.class,”1”);?
Query query=session.createQuery(“from Order order where order.customer=:customer ”);?
query. setEntity(“customer”,customer);?
List list=query.list();?

上面的代碼會生成類似如下的SQL語句:?

Select * from order where customer_ID=’1’;


二 query分頁查詢設置

Session session = this.sessionFactory.openSession();
Query query=session.createQuery("from User u where u.name=:name");?
query.setParameter("name","zhansan1");?
query.setFirstResult(10);
query.setMaxResults(5);
List<User> userList = query.list();

?

總結

以上是生活随笔為你收集整理的(2)hibernate HQL命名查询和Query接口的分页查询的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。