首页 > 数据库技术 > 详细

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

时间:2019-01-05 23:12:47      阅读:285      评论:0      收藏:0      [点我收藏+]

一、前言

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

一条简单的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结果行数的几种方法

原文:https://www.cnblogs.com/grey-wolf/p/10209946.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!