hibernate求和

hibernate求和使用的是 createSQLQuery方法,用以执行sql语句。这里面具体hibernate相关session等操作这里不介绍了,不懂看前面文章。
service层,执行相应sql语句:
StringBuffer sb=new StringBuffer();
sb.append("SELECT SUM(u.userAnswerScore) FROM t_user_answer u WHERE u.userId=:userId and u.questionnaireId=:questionnaireId" );
Map<String, Object> map=new HashMap<String, Object>();
map.put("userId",userId);
map.put("questionnaireId",questionnaireId);
int count=userAnswerDao.executeSqlHql(sb.toString(), map);
return count;
//在hibernate具体sql操作dao处执行sql:
public int executeSqlHql(String hql, Map<String, Object> params) {
Query q = this.getCurrentSession().createSQLQuery(hql);
if (params != null && !params.isEmpty()) {
for (String key : params.keySet()) {
if(params.get(key) instanceof Object[])
q.setParameterList(key, (Object[])params.get(key));
else if(params.get(key) instanceof Object)
q.setParameter(key, params.get(key));
}
}
List<String[]> sum=q.list();
//获取返回的第一个值,即查询的和
String  object=String.valueOf(sum.get(0));
int Int=(int) Double.parseDouble(object); //注意类型转换
return Int;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值