当前位置: 首页 > article >正文

JPA查询部分字段的最佳实践

最近在接手一个项目,用的是JPA,以前没使用过。在开发新的需求过程中,发现有查询部分字段的情况,网上逛了半天,发现都是抄来抄去的“古文”。于是用英文搜索了下,总结了以下几点。

版本信息:Spring Boot 2.3.7 

1. 不需要新建Entity,但是需要一个所有部分字段的构造函数。当然如果你觉得返回的Entity中包含大量null值字段,以及多一个所有部分字段的构造函数不妥,也可以新建一个子集Entity。

2. 不使用findAll,而是使用EntityManager来执行CriteriaQuery.multiselect的查询。

3. 没有用@Query,因为我的查询是动态的。

4. 也可以支持分页。

示例代码,用模糊查询Merchant的部分字段,并要求分页。

(不过,总觉得这些代码有些冗余,不知道有没有其它更优的写法)

public Page<Merchant> listMerchant(String name, Pageable pageable) {
	CriteriaBuilder totalRowsCb = this.entityManager.getCriteriaBuilder();
	CriteriaQuery<Long> totalRowsQuery = totalRowsCb.createQuery(Long.class);
	Root<Merchant> totalRowsRoot = totalRowsQuery.from(Merchant.class);
	totalRowsQuery.where(totalRowsCb.like(totalRowsRoot.get("name"), "%" + name + "%"));
	totalRowsQuery.select(totalRowsCb.count(totalRowsRoot));
	Long totalRows = entityManager.createQuery(totalRowsQuery).getSingleResult();

	CriteriaBuilder listCb = this.entityManager.getCriteriaBuilder();
	CriteriaQuery<Merchant> listQuery = listCb.createQuery(Merchant.class);
	Root<Merchant> listRoot = listQuery.from(Merchant.class);
	List<Order> orderList = QueryUtils.toOrders(pageable.getSort(), listRoot, listCb);

	listQuery .multiselect(
			listRoot.get("mid").alias("mid"),
			listRoot.get("name").alias("name"),
			listRoot.get("businessName").alias("businessName"),
			listRoot.get("contactEmail").alias("contactEmail"),
			listRoot.get("status").alias("status"),
			listRoot.get("accountStatus").alias("accountStatus")
	).where(listCb.like(listRoot.get("name"), "%" + name + "%")).orderBy(orderList);

	List<Merchant> merchantList = entityManager
			.createQuery(listQuery)
			.setMaxResults(pageable.getPageSize())
			.setFirstResult((int)pageable.getOffset())

			.getResultList();

	return new PageImpl<>(merchantList, pageable, totalRows);
}


http://www.kler.cn/a/459518.html

相关文章:

  • 【竞技宝】CS2:HLTV 2024 TOP11-w0nderful
  • 【MySQL基础篇】三、表结构的操作
  • 基于单片机的家庭智能垃圾桶(论文+源码)
  • 一文讲清楚HTTP常见的请求头和应用
  • Vue3 内置组件之component
  • 昆仑万维大数据面试题及参考答案
  • Python 中的 with open:文件操作的最佳实践
  • 发布远程组件vue2+Webpack和vue3+vite
  • 面试场景题系列:设计云盘系统
  • jmeter设置tps、响应时间监测时间间隔
  • DigitalOcean Kubernetes现已支持VPC natvie集群
  • 【深度学习】Pytorch框架介绍
  • 基于单片机的温湿度采集系统(论文+源码)
  • 整车厂如何规划构建汽车集成安全团队的软件研发能力
  • win10 indy加载ssl 出错could not load ssl library
  • k8s七层代理Ingress(基础知识)
  • C 语言: scanf 函数详解
  • web3基于zkEVM的L2扩容方案-Scroll
  • 华为OD机试真题---服务器广播
  • 活动预告 | Microsoft Azure 在线技术公开课:使用 Azure OpenAI 服务构建生成式应用
  • webrtc音频模块(五) AudioState和AudioDeviceBuffer
  • 服务器nfs文件共享
  • 实验室课程|基于SprinBoot+vue的实验室课程管理系统(源码+数据库+文档)
  • 使 el-input 内部的内容紧贴左边
  • 013-spring的注解整合第三方框架
  • 「下载」智慧园区及重点区域安全防范解决方案:框架统一规划,建设集成管理平台