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

本文介绍了通过Criteria、原生SQL及Hibernate查询语言三种方法在数据库中查询行数和列表的具体实现,包括设置参数、执行查询及获取结果的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、前言

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

一条简单的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();

 

查询列表:

Criteria criteria = getCriteria();
criteria.add(Restrictions.eq("eventId", eventInformationId));
List<EventTaskAssignment> list = criteria.list();

 

二、通过原生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;

 查询列表:

1、返回的item为数据库表对应po

        SQLQuery query = getSession().createSQLQuery(sqlQuery);
        query.setParameter("userId", userId);

        query.addEntity(EventTaskAssignment.class);
        List<EventTaskAssignment> items = query.list();

 

2、返回的item为vo

        SQLQuery query = getSession().createSQLQuery(sqlBuffer.toString());
        query.setParameter("eventInformationId", eventInformationId);
        query.addScalar("userId", StandardBasicTypes.STRING);
        query.addScalar("userName", StandardBasicTypes.STRING);
        query.setResultTransformer(Transformers.aliasToBean(UserRoles.class));
        List<UserRoles> list = query.list();

 

三、通过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();

 

转载于:https://www.cnblogs.com/grey-wolf/p/10209946.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值