Hibernate 查询sql结果行数的几种方法

Posted 低级知识传播者

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Hibernate 查询sql结果行数的几种方法相关的知识,希望对你有一定的参考价值。

一、前言

这个东西,难度几乎没有,就是繁琐。

一条简单的select count(*) from table_name

都能有多种书写方式。

总是忘,这里记录下。

一 、通过Criteria 查询

 

        Criteria criteriaCount = getCriteria();
        criteriaCount = criteriaCount.add(Restrictions.eq("dispatchTaskId", dispatchTaskId));
        criteriaCount.setProjection(Projections.rowCount());
        Integer totalCount = ((Long) criteriaCount.uniqueResult()).intValue();

 

二、通过原生sql查询

        SQLQuery queryCount = getSession().createSQLQuery("SELECT COUNT(*) FROM incidentInformation  WHERE ii.incidentInformationId = :incidentInformationId AND dti.taskstate = :taskstate");

        queryCount.setParameter("incidentInformationId", incidentInformationId);
        queryCount.setParameter("taskstate", ETaskStatus.STATUS_INIT.getStatusValue());
        int count = ((BigDecimal) queryCount.uniqueResult()).intValue();

        return count;

 

三、通过hibernate的查询语言查询

        String countHql = "select count(*) from  a  where and a.approveResult = :approveResult and a.approverId = :approverId";
        Query countQuery = getSession().createQuery(countHql);
        countQuery.setParameter("approverId", approverId);
        int count = ((Long) countQuery.uniqueResult()).intValue();

 

以上是关于Hibernate 查询sql结果行数的几种方法的主要内容,如果未能解决你的问题,请参考以下文章

如何将 SQL 查询结果行作为具有不同标题名称的列? [关闭]

如何使用 Entity Framework Core 5.0 将复杂 SQL 查询的结果行映射到自定义 DTO?

怎样用sqlserver将查询结果行转列

php中mysqli 处理查询结果集的几个方法

SQL:多次重复结果行,并对行进行编号

Hibernate的session.createSQLQuery的几种查询方式