spring data jpa分页查询示例代码
作者:码农的天空 发布时间:2023-01-09 14:51:50
标签:spring,data,jpa
最近项目上用就hibernate+spring data jpa,一开始感觉还不错,但是随着对业务的复杂,要求处理一些复杂的sql,就顺便研究了下,把结果记录下,以便日后查看。用到Specification,需要继承JpaSpecificationExecutor接口。(下面代码有的分页从0开始作为第一页,有的从1开始作为作为第一页,我也忘记,请自己测试)
DAO层:
import java.util.List;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.JpaSpecificationExecutor;
import org.springframework.data.jpa.repository.Modifying;
import org.springframework.data.jpa.repository.Query;
import org.springframework.stereotype.Repository;
@Repository
public interface CameraInfoRepo extends JpaRepository<CameraInfoPO, String>, JpaSpecificationExecutor<CameraInfoPO> {
@Query("select c from CameraInfoPO c where c.deviceInfo.id = ?1")
public List<CameraInfoPO> findCamerasByDeviceId(String listDeviceInfoId);
//更新之后不清空缓存,在一个事务里查询到旧数据(hibernate)
@Modifying
@Query(value = "update CameraInfoPO c set c.isEnabled = 1 where c.id = ?1")
public void updateEnabled(String cameraId);
//更新之后清空缓存,不保留旧对象(hibernate)
@Modifying(clearAutomatically = true)
@Query(value = "update CameraInfoPO c set c.isEnabled = 0 where c.id = ?1")
public void updateUnEnabled(String cameraId);
//带条件的分页查询
public Page<CameraInfoPO> findByIsEnabled(Integer isEnabled, Pageable pageable);
}
DAO实现层
import java.util.ArrayList;
import java.util.List;
import javax.annotation.Resource;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import javax.persistence.TypedQuery;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Predicate;
import javax.persistence.criteria.Root;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageImpl;
import org.springframework.data.domain.Pageable;
import org.springframework.data.jpa.domain.Specification;
import org.springframework.stereotype.Repository;
@Repository
public class CameraInfoRepoImpl {
@PersistenceContext
private EntityManager em;
@Resource
private CameraInfoRepo cameraInfoRepo;
public Page<CameraInfoPO> findCameraInfoByPage(Pageable pageable, Integer isEnabled) {
//CriteriaBuilder,用来构建CritiaQuery的构建器对象
CriteriaBuilder criteriaBuilder = em.getCriteriaBuilder();
//CriteriaQuery,它包含着查询语句的条件各个部分,比如:select 、from、where、group by、order by等
CriteriaQuery<CameraInfoPO> criteriaQuery = criteriaBuilder.createQuery(CameraInfoPO.class);
//查询根,用于获取查询实例的属性,通过CriteriaQuery的from方法获取
Root<CameraInfoPO> rootFrom = criteriaQuery.from(CameraInfoPO.class);
//查询条件
List<Predicate> predicates = new ArrayList<Predicate>();
if (null != isEnabled) {
Predicate predicate = criteriaBuilder.equal(rootFrom.get("isEnabled").as(Integer.class), isEnabled);
predicates.add(predicate);
}
//格式化参数
criteriaQuery.where(criteriaBuilder.and(predicates.toArray(new Predicate[predicates.size()])));
//默认按照id排序(从小到大)
criteriaQuery.orderBy(criteriaBuilder.asc(rootFrom.get("id")));
//SQL查询对象
TypedQuery<CameraInfoPO> createQuery = em.createQuery(criteriaQuery);
//分页参数
Integer pageSize = pageable.getPageSize();
Integer pageNo = pageable.getPageNumber();
//计数查询结果条数
TypedQuery<CameraInfoPO> createCountQuery = em.createQuery(criteriaQuery);
// 实际查询返回分页对象
int startIndex = pageSize * pageNo;
createQuery.setFirstResult(startIndex);
createQuery.setMaxResults(pageable.getPageSize());
Page<CameraInfoPO> pageRst =
new PageImpl<CameraInfoPO>(createQuery.getResultList(), pageable, createCountQuery.getResultList().size());
return pageRst;
}
//制造查询条件结果(建议存放map)
private Specification<CameraInfoPO> getWhereClause(final Integer isEnabled) {
return new Specification<CameraInfoPO>() {
public Predicate toPredicate(Root<CameraInfoPO> r, CriteriaQuery<?> q, CriteriaBuilder cb) {
Predicate predicate = cb.conjunction();
if (null != isEnabled) {
predicate = cb.equal(r.get("isEnabled").as(Integer.class), isEnabled);
}
return predicate;
}
};
}
//单表根据查询条件的分页
public Page<CameraInfoPO> findCameraInfoByPageForJpa(Pageable pageable, Integer isEnabled) {
Specification<CameraInfoPO> spec = getWhereClause(isEnabled);
Page<CameraInfoPO> pageRst = cameraInfoRepo.findAll(spec, pageable);
return pageRst;
}
}
还有另外一种就更简单了,如果只是根据表里面的一个或者几个字段,可以直接写jpa实现,不用复杂
Pageable pageable = new PageRequest(1, 1);
Page<CameraInfoPO> page = cameraInfoRepo.findByIsEnabled(1, pageable);
来源:http://blog.csdn.net/rshw123456/article/details/51694129
0
投稿
猜你喜欢
- Java中有哪些队列ArrayBlockingQueue 使用ReentrantLockLinkedBlockingQueue 使用Reen
- 仅供学习交流,禁止商业用途。如侵害利益,联系必删!前言最近一位小伙伴钟爱二次元文化,于是找到半次元这个app,但是很快他就遇到了问题。一、案
- AuthenticationProvider解析首先进入到AuthenticationProvider源码中可以看到它只是个简单的接口里面也
- DeferredResult的超时处理,采用委托机制,也就是在实例DeferredResult时给予一个超时时长(毫秒),同时在onTime
- 当使用spring-Boot时,嵌入式Servlet容器通过扫描注解的方式注册Servlet、Filter和Servlet规范的所有 * (
- Android 自动获取验证码的两种方式分别是BroadcastReceiver及ContentObserver,两种方式都需要进行注册、取
- 引言: 在Spring Boot应用中,基于数据某个字段进行排序是一个非常常用的需求,这里将给出Sort的三种常用用法,基于分页的应用,大家
- 目录注解是什么?元注解是什么?标准的元注解:@Target元注解:@Retention元注解:@Documented元注解:@Inherit
- Mybatis Plus流式查询mybatis plus 中自定义如下接口,就可以实现流式查询,mybatis 中同样适用。@Select(
- Dubbo作为国内最出名的分布式服务框架,是Java程序员必备必会的框架之一,更是中高级测试面试过程中经常会问的技术,无论你是否用过,你都必
- 这篇文章主要介绍了spring cloud gateway请求跨域问题解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定
- 前言是否会遇到这样的场景,你向线程池提交了多个任务,你希望这批任务全部完成后能够反向通知你。你可能会使用线程计数的方式,等到计数器累加到提交
- Spring相关的依赖导入进去,即可使用spring的定时任务!<!-- spring核心包 -->
- 本文实例为大家分享了Java实现颜色渐变效果的具体代码,供大家参考,具体内容如下RGB色彩,在自然界中肉眼所能看到的任何色彩都可以由红(R)
- 1、找奇数:public static boolean isOdd(int i){ return i % 2 == 1; }上面的方法真
- 多数据源的目的在于一个代码模块可调用多个数据库的数据进行某些业务操作。MyBatis-Plus开发者写了一个多数据源叫dynamic-dat
- 本文实例讲述了C#多线程学习之生产者和消费者用法。分享给大家供大家参考。具体实分析如下:前面的文章说过,每个线程都有自己的资源,但是代码区是
- 此项目使用了OpenCVSharp加载本地摄像头,多个摄像头支持切换展示,也可以展示rtsp地址。使用NuGet如下:代码如下一、创建Mai
- 个人认为单例模式是设计模式中最简单也是最常用的一种,是对有限资源合理利用的一种方式。这个模式看似简单,但是其中蕴含了关于并发、类加载、序列化
- 一、Thread 类了解如何使用Thread 类实现多线程之后,继续学习Thread 类实现多线程之后的相关功能及方法。1、操作线程名称的方