例如:
String hql = “from student order bysname,sid desc”;
首先按照学生姓名进行升序排序,对于学生姓名相同的对象将按照学生编号进行降序排列。
统计函数的使用
共有5个统计函数为:avg(),sum(),min(),max(),count(),分别用来求平均数,求和,求最小值,求最大值,计数的功能。
与SQL中的统计函数不同的是:SQL中的统计韩式是用来对数据库表的字段进行操作,而HQL中的统计函数则是对持久化类的属性进行操作。
示例1:统计学生数目
String hql=”select count(*) from Student”;
Long n =(Long)session.createQuery(hql).uniqueResult();
示例2:查询所有学生的平均分、最低分、最高分。
String hql = “select avg(score),min(score),max(score)from Student”;
Object obj[] =(Object[])session.createQuery(hql).uniqueResult();
分组查询
示例:统计各个班级的学生人数
select gid,count(*) from Student group by gid;
having子句用于用于对分组结果添加查询条件。
示例:统计人数大于20的班级的学生人数
select gid,count(*) from Student group by gid having count(*)>20
分页查询
使用Hibernate Query接口提供的方法。
1、setFirstResult()设置第一条记录的位置。
2、setMaxResult()设置最大返回的记录条数。
分页实现:
1、根据结果获得总记录数
Query query =session.createQuery(“from Student”);
Listlist = query.list();
int count =list.size(); 2、计算总的页数
inttotalpages = (count%pageSize==0) (count/pageSize):(count/pageSize+1); 3、实现分页
query.setFirstResult((pageIndex-1)*pageSize);
query.setMaxResults(pageSize);
List result =query.list(); 子查询
示例:查询成绩高于张华和赵飞成绩的学生信息
from Student where score >all(select score fromStudent where sname=’张华’ or sname=’赵飞’);
all的含义是分数要高于括号内所有的分数,如果题目要求查询高于张华或赵飞的成绩,应该使用any关键字。
连接查询
使用join子句实现多个持久化对象之间的联合查询。一般是针对连个持久化对象进行查询。
查询分类

示例,用到的数据库表为班级表和学生表,表情况如下:


内连接语法:
from Entity inner join Entity.property
Entity指明了一个持久化类,Entity.propery是指明了第一个持久化类中与第二个持久化类建立关联的属性
例如:查询班级和学生中的所有匹配数据。
from Grade g inner join g.students等价于以下两个语句:from Grade g,Student s whereg=s.grade
from Grade g,Student s where g.gid=s.grade.gid;
左外连接语法
from Entity left outer join Entity.property
例如,显示班级和学生中的匹配信息,并且显示没有学生的班级
from Grade g left join g.students;
右外连接语法:
from Entity right outer join Entity.property
例如,显示班级和学生中的匹配信息,并且显示没有班级的学生信息
from Grade g right join g.students;或者
from Student s left join s.grade;