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();
查询列表:
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();
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端