Hibernate count如何映射?HQL别名字段问题?

问:hibernate, select name, count(*) from table group by name。这句话应该怎么用HQL语句执行?或者在hibernate中该怎么查出每个name对应的count?

 

答:String hql = "select name, count(*) from table group by name";   //跟sql语句差不多的,不过这里的name是类的属性,table 是类名,因为HQL是面向对象的查询的语言。

首先要获得session,你懂的,
然后  Query query = session.createQuery(hql);
List list = query.list();
获取list里面的name :
Iterator it = lits.iterator();
if(it.hasNext()){
    Object[]  obj = (Object[]) it.next();
    String name = obj[0];
    int count = obj[1];
}

 

在项目开发中的具体情况:

Java代码   收藏代码
  1. //关键是处理count映射问题。120221 hjl  
  2.                 String q = "select userId, nickName, count(id)  from BbscsLogintimes  where LoginYear = ? and LoginMonth = ?  group by userId order by col_2_0_ desc";  
  3.      
  4.                 Query query = session.createQuery(q);  
  5.                 query.setLong(0, Long.valueOf(year));  
  6.                 query.setLong(1, Long.valueOf(mon));    
  7.                 List list = query.list();      
  8.                   
  9.                 //封装  
  10.                 List list2 = new ArrayList();  
  11.                 BbscsLogintimes logintimes= null;  
  12.                 Iterator it = list.iterator();  
  13.                 long j = 1;  
  14.                 while(it.hasNext()){  
  15.                     logintimes = new BbscsLogintimes();  
  16.                     Object[]  obj = (Object[]) it.next();  
  17.                     logintimes.setOrderId(j);  
  18.                     logintimes.setOrderName((String) obj[1]);  
  19.                     logintimes.setOrderNum((Integer)obj[2]);  
  20.                     list2.add(logintimes);  
  21.                     j++;  
  22.                 }  

 

说明:HQL别名字段

hibernate执行时打印出HQL
<property name="show_sql">true</property>

Hibernate: select bbscslogin0_.UserID as col_0_0_, bbscslogin0_.NickName as col_1_0_, count(bbscslogin0_.ID) as col_2_0_ from bbscs6.bbscs_logintimes bbscslogin0_ where LoginYear=? and LoginMonth=? group by bbscslogin0_.UserID order by col_2_0_ desc limit ?

UserID别名 ~ col_0_0_
NickName别名 ~ col_1_0_
count(bbscslogin0_.ID)别名 ~ col_2_0_

所以上面的HQL语句:group by userId order by col_2_0_ desc  //按count统计量来降序排列。


转载于:http://simpledev.iteye.com/blog/1433282

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值