Hibernate中對動態(tài)查詢參數(shù)綁定提供了豐富的支持,那么什么是查詢參數(shù)動態(tài)綁定呢?其實如果我們熟悉傳統(tǒng)JDBC編程的話,我們就不難理解查詢參數(shù)動態(tài)綁定,如下代碼傳統(tǒng)JDBC的參數(shù)綁定:
PrepareStatement pre=connection.prepare(“select * from User where user.name=?”);
pre.setString(1,”zhaoxin”);
ResultSet rs=pre.executeQuery();
在Hibernate中也提供了類似這種的查詢參數(shù)綁定功能,而且在Hibernate中對這個功能還提供了比傳統(tǒng)JDBC操作豐富的多的特性,在Hibernate中共存在4種參數(shù)綁定的方式,下面我們將分別介紹:
A、 按參數(shù)名稱綁定:
在HQL語句中定義命名參數(shù)要用”:”開頭,形式如下:
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分別定義了命名參數(shù)customername和customerage,然后用Query接口的setXXX()方法設定名參數(shù)值,setXXX()方法包含兩個參數(shù),分別是命名參數(shù)名稱和命名參數(shù)實際值。
B、 按參數(shù)位置邦定:
在HQL查詢語句中用”?”來定義參數(shù)位置,形式如下:
Query query=session.createQuery(“from User user where user.name=? and user.age =? ”);
query.setString(0,name);
query.setInteger(1,age);
同樣使用setXXX()方法設定綁定參數(shù),只不過這時setXXX()方法的第一個參數(shù)代表邦定參數(shù)在HQL語句中出現(xiàn)的位置編號(由0開始編號),第二個參數(shù)仍然代表參數(shù)實際值。
注:在實際開發(fā)中,提倡使用按名稱邦定命名參數(shù),因為這不但可以提供非常好的程序可讀性,而且也提高了程序的易維護性,因為當查詢參數(shù)的位置發(fā)生改變時,按名稱邦定名參數(shù)的方式中是不需要調(diào)整程序代碼的。
C、 setParameter()方法:
在Hibernate的HQL查詢中可以通過setParameter()方法邦定任意類型的參數(shù),如下代碼:
String hql=”from User user where user.name=:customername ”;
Query query=session.createQuery(hql);
query.setParameter(“customername”,name,Hibernate.STRING);
如上面代碼所示,setParameter()方法包含三個參數(shù),分別是命名參數(shù)名稱,命名參數(shù)實際值,以及命名參數(shù)映射類型。對于某些參數(shù)類型setParameter()方法可以更具參數(shù)值的
Java類型,猜測出對應的映射類型,因此這時不需要顯示寫出映射類型,像上面的例子,可以直接這樣寫:
query.setParameter(“customername”,name);但是對于一些類型就必須寫明映射類型,比如java.util.Date類型,因為它會對應Hibernate的多種映射類型,比如Hibernate.DATA或者Hibernate.TIMESTAMP。
D、 setProperties()方法:
在Hibernate中可以使用setProperties()方法,將命名參數(shù)與一個對象的屬性值綁定在一起,如下程序代碼:
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對象實例的屬性值匹配到命名參數(shù)上,但是要求命名參數(shù)名稱必須要與實體對象相應的屬性同名。
這里還有一個特殊的setEntity()方法,它會把命名參數(shù)與一個持久化對象相關聯(lián),如下面代碼所示:
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’;