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 ;
}
}

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值