例如,如果我们有一个表Books,我们如何用hibernate计算图书记录的总数?
你可以试试count(*)
Integer count = (Integer) session.createQuery("select count(*) from Books").uniqueResult();
其中Books是类外的名称,而不是数据库中的表。
对于Hibernate的旧版本(<5.2):
假设类名为Book:
return (Number) session.createCriteria("Book")
.setProjection(Projections.rowCount())
.uniqueResult();
它至少是一个数字,很可能是一个长。
在Java中,我通常需要返回int并使用这种形式:
int count = ((Long)getSession().createQuery("select count(*) from Book").uniqueResult()).intValue();
以下是官方hibernate文档告诉我们的:
查询结果不返回,可以统计查询结果个数:
( (Integer) session.createQuery("select count(*) from ....").iterate().next() ).intValue()
但是,它并不总是返回Integer实例,因此为了安全起见,最好使用java.lang.Number。
Long count = (Long) session.createQuery("select count(*) from Book").uniqueResult();
如果您正在使用Hibernate 5+,那么查询将被修改为
Long count = session.createQuery("select count(1) from Book")
.getSingleResult();
或者如果你需要TypedQuery
Long count = session.createQuery("select count(1) from Book",Long.class)
.getSingleResult();
这在Hibernate 4(已测试)中有效。
String hql="select count(*) from Book";
Query query= getCurrentSession().createQuery(hql);
Long count=(Long) query.uniqueResult();
return count;
其中getCurrentSession()为:
@Autowired
private SessionFactory sessionFactory;
private Session getCurrentSession(){
return sessionFactory.getCurrentSession();
}
这很简单,只需运行以下JPQL查询:
int count = (
(Number)
entityManager
.createQuery(
"select count(b) " +
"from Book b")
.getSingleResult()
).intValue();
我们将类型转换为Number的原因是一些数据库将返回Long,而另一些数据库将返回BigInteger,因此为了可移植性,最好将类型转换为Number并获得int或Long,这取决于您希望统计的行数。
推荐文章
- 在流中使用Java 8 foreach循环移动到下一项
- 访问限制:'Application'类型不是API(必需库rt.jar的限制)
- 用Java计算两个日期之间的天数
- 确定记录是否存在的最快方法
- 如何配置slf4j-simple
- 在Jar文件中运行类
- 带参数的可运行?
- 我如何得到一个字符串的前n个字符而不检查大小或出界?
- 我可以在Java中设置enum起始值吗?
- Java中的回调函数
- c#和Java中的泛型有什么不同?和模板在c++ ?
- 在Java中,流相对于循环的优势是什么?
- Jersey在未找到InjectionManagerFactory时停止工作
- 在Java流是peek真的只是调试?
- Recyclerview不调用onCreateViewHolder