例如,如果我们有一个表Books,我们如何用hibernate计算图书记录的总数?
当前回答
对于Hibernate的旧版本(<5.2):
假设类名为Book:
return (Number) session.createCriteria("Book")
.setProjection(Projections.rowCount())
.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文档告诉我们的:
查询结果不返回,可以统计查询结果个数:
( (Integer) session.createQuery("select count(*) from ....").iterate().next() ).intValue()
但是,它并不总是返回Integer实例,因此为了安全起见,最好使用java.lang.Number。
你可以试试count(*)
Integer count = (Integer) session.createQuery("select count(*) from Books").uniqueResult();
其中Books是类外的名称,而不是数据库中的表。
Long count = (Long) session.createQuery("select count(*) from Book").uniqueResult();
在Java中,我通常需要返回int并使用这种形式:
int count = ((Long)getSession().createQuery("select count(*) from Book").uniqueResult()).intValue();
推荐文章
- 在Java中转换字符串到日历对象
- 在java中使用wait()和notify()的简单场景
- 增强的for循环中的Null检查
- c# vs Java Enum(适合c#新手)
- 如何在不强制转换的情况下将double转换为long ?
- for循环和for-each循环在性能上有区别吗?
- 你如何比较两个版本的字符串在Java?
- 为什么在Java和。net中不能修改字符串?
- java.util.Random真的那么随机吗?我怎么能生成52!(阶乘)可能的序列?
- ZoneOffset之间的区别是什么。UTC和ZoneId.of(“UTC”)?
- 类未找到:IntelliJ中的空测试套件
- 将JAR文件添加到Spark作业- Spark -submit
- REST API - dto还是不是?
- 使用LIMIT/OFFSET运行查询,还可以获得总行数
- JavaFX应用程序图标