我们都知道在Hibernate中使用createQuery和createSQLQuery的最大区别就是前者是使用hql语句,后者使用的是sql语句
之前在使用createSQLQuery进行select count(*) 查询时出现一个异常,可能是使用createQuery习惯了,一直没找到错误的原因
原本的代码是这样写的:
long count = (Long) getSessionFactory().getCurrentSession().createSQLQuery(sb.toString()).uniqueResult();
记得使用createQuery这样写是没问题的,但现在这里一直报BigDecimal格式转换的异常,后面没办法只能debug以下,发现返回值就是BigDecimal类型,无奈只能这么写就没问题了
Query query = getSessionFactory().getCurrentSession()
.createSQLQuery(sb.toString());
Object object = query.uniqueResult();
if (object instanceof BigDecimal) {
BigDecimal bd = (BigDecimal) query.uniqueResult();
count = bd.intValue();
}