EJB3 JPA JPQL 语句 查询 使用 函数 分页 子查询(二)

 

 

计算函数
HPQL 定义的计算函数包括:
ABS  绝对值
SQRT  平方根
MOD  取余数
SIZE  取集合的数量
 
例:
// 查询所有 Order  的订单号及其订单项的数量
select o.orderid, size(o.orderItems) from Order as o group by o.orderid
// 查询所有 Order  的订单号及其总金额 /10  的余数
select o.orderid, mod(o.amount, 10) from Order as o
 
 
子查询
子查询可以用于 WHERE  HAVING  条件语句中
例:
// 查询年龄为 26  岁的购买者的所有 Order
select o from Order as o where o.ower in(select p from Person as p where p.age =26)
 
 
结果集分页
有些时候当执行一个查询会返回成千上万条记录,事实上我们只需要显示一部分数据。这时我们需要对结果集进行分页 QueryAPI 有两个接口方法可以解决这个问题: setMaxResults( )  setFirstResult( )
 
setMaxResults 方法设置获取多少条记录
setFirstResult 方法设置从结果集中的那个索引开始获取 (假如返回的记录有 3 条,容器会自动为记录编上索引,索引从 0 开始,依次为 0 1 2
 
例:
public  List getPersonList( int  max, int  whichpage) {
try  {
int  index = (whichpage-1) * max;
Query query =  em .createQuery( "from Person p order by personid asc" );
List list = query. setMaxResults(max) .
setFirstResult(index) .
getResultList();
em .clear(); // 分离内存中受EntityManager管理的实体bean,让VM进行垃圾回收
return  list;
}  catch  (Exception e) {
e.printStackTrace();
return null ;
}
}

 

 

 

 

你可能感兴趣的:(bean,jpa)