在Hibernate3.0中废除了find()方法,取而代之的是Query接口
一、绑定参数
1、使用“?”指定参数
通过Query接口可以先设定查询参数,然后通过setXXX()等方法,将指定的参数值填入,而不用每次编写完整的HQL。
Query query = session.createQuery(“from Student s where s.age>? and s.name like ?”)
query.setInteger(0,25);
query.setString(1,”%clus%”);
……………….
2、使用“:“后跟变量的方法设置参数
可以使用命名参数来取代“?“设置参数的方法,这可以不用来依照特定的顺序来设定参数值,比如上面的示例代码也可以写为:
Query query = session.createQuery(“from Student s where s.age>:minAge and s.name like :likeName”)
query.setInteger(minAge,25);
query.setString(likeName,”%clus%”);
………………..
4、setEntity()方法
setEntity()方法把参数与持久化类的示例绑定
Team team = (Team)session.get(Team.class,”aaa565efc767”);
Query query = session.createQuery(“from Student s where s.team>:team”)
query. setEntity(“team”,team);
…………………………..
5、setParameter()方法
setParameter()方法全称是setParameter(String paraName,实例,实例类型),这个方法可以绑定任意类型的参数。如可把上面的改写为:
query.setParameter(“team”,team,Hibernate.entity(Team.class)),其中,Hibernate.entity()指定映射的Hibernate 类型,也可以不要,如:
query.setParameter(“team”,team)
……………..
6、setPropertyies()方法
setPropertyies()的全称是setPropertyies(类实例)。它将类实例的属性名与参数值相对应,如:
Student
stu = new Student();
Stu.setAge(99);
Query query = session.createQuery(“from Student s where s.age=:age”);
query.setProperties(stu);
……………….
二、使用命名查询
可以将HQL语句写在程序之外,以避免硬编码在程序之中,需要的时候可以随时更改,在*.hbm.xml中使用<query/>标签,并在
<![CDATA[
与
]]>
之间编写
HQL
,编写的位置是在
</class>
节点之后
</hibername-mapping>
节点之间。如:
<?
xml
version
=
"1.0"
encoding
=
"UTF-8"
?>
<!
DOCTYPE
hibernate-mapping
PUBLIC
"-//Hibernate/Hibernate Mapping DTD//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"
>
<
hibernate-mapping
>
<
class
name
=
"com.kissjava.Student"
table
=
"student"
lazy
=
"true"
>
<
id
name
=
"id"
unsaved-value
=
"null"
>
<
generator
class
=
"uuid.hex"
/>
</
id
>
<
property
name
=
"name"
type
=
"string"
/>
<
property
name
=
"age"
type
=
"int"
/>
</
class
>
<!--
设置命名查询
-->
<
query
name
=
"namedQueryAgeName"
>
<!--
此查询被调用的名字
-->
<![CDATA[
from Student s where s.age>:minAge and s.name like:likeName
]]>
</
query
>
</
hibernate-mapping
>
<query>
的
name
属性用来设定查询外部
HQL
时的名称依据,使用命名查询的源码如下:
Query query = session.getNamedQuery(“
namedQueryAgeName”)
query.setInteger(minAge,25);
query.setString(likeName,”%clus%”);
………………..