例如,如果我们有一个表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();

它至少是一个数字,很可能是一个长。

你可以试试count(*)

Integer count = (Integer) session.createQuery("select count(*) from Books").uniqueResult();

其中Books是类外的名称,而不是数据库中的表。

这很简单,只需运行以下JPQL查询:

int count = (
(Number)
    entityManager
    .createQuery(
        "select count(b) " +
        "from Book b")
    .getSingleResult()
).intValue();

我们将类型转换为Number的原因是一些数据库将返回Long,而另一些数据库将返回BigInteger,因此为了可移植性,最好将类型转换为Number并获得int或Long,这取决于您希望统计的行数。

如果您正在使用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();

在Java中,我通常需要返回int并使用这种形式:

int count = ((Long)getSession().createQuery("select count(*) from Book").uniqueResult()).intValue();