Java简单高效实现分页功能

所属分类: 软件编程 / java 阅读数: 92
收藏 0 赞 0 分享

今天想说的就是能够在我们操作数据库的时候更简单的更高效的实现,现成的CRUD接口直接调用,方便快捷,不用再写复杂的sql,带吗简单易懂,话不多说上方法

1、Utils.java工具类中的方法

 /** 2 * 获取Sort
  *
  * @param direction - 排序方向
  * @param column - 用于排序的字段
  */
 public static Sort getSort(String direction,String column){
   Sort sort = null;
   if(column == null || column == "") return null;
   if(direction.equals("asc")||direction.equals("ASC")){
     sort = Sort.by(Sort.Direction.ASC,column);
   }else {
     sort = Sort.by(Sort.Direction.DESC,column);
   }
   return sort;
 }
 /**
 * 获取分页
 * @param pageNumber 当前页
 * @param pageSize 页面大小
 * @param sort 排序;sort为空则不排序只分页
 * @return 分页对象
 */
 public static Pageable getPageable(int pageNumber,int pageSize,Sort sort){
  if(sort!=null){
    return PageRequest.of(pageNumber,pageSize,sort);
  }
    return PageRequest.of(pageNumber,pageSize);
 }
 /**
   * 判断String是否为空
   * @param str
   * @return
   */
   private static boolean isEmpty(String str){
     if(str.equals(null)||str.equals("")) return true;
     return false;
   } 

2、实现类

这里查询相关参数是前端传的,所以用默认值了,查询条件可以是多条件动态,排序也可以是动态的,只要传排序字段和排序方向对号入座即可。

@Override
public Page<User> findAll() {
  // 创建测试对象
  User user = new User();
  user.setName("1");
  Sort sort = Utils.getSort("asc","name");
  Pageable pageable = Utils.getPageable(0,5,sort);
  // 调用组装查询条件方法
  Specification<User> spec = getSpecification(user);
  return userRepository.findAll(spec,pageable);
}

/**
 * 组装查询条件
 * @param user -查询相关对象
 * @return 返回组装过的多查询条件
 */
private Specification<User> getSpecification(User user) {
  Specification<User> specification = new Specification<User>() {
    @Override
    public Predicate toPredicate(Root<User> root, CriteriaQuery<?> criteriaQuery, CriteriaBuilder criteriaBuilder) {
      List<Predicate> predicates = new ArrayList<>();
      // 判断条件不为空
      if(!Utils.isEmpty(user.getName())){
        predicates.add(criteriaBuilder.like(root.get("name"),user.getName()));
      }
      return criteriaQuery.where(predicates.toArray(new Predicate[predicates.size()])).getRestriction();
    }
  };
  return specification;
}

3.repository类中这么写

@Repository
public interface UserRepository extends JpaRepository<User, Integer>, JpaSpecificationExecutor<User> {}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

利用MultipartFile实现文件上传功能

这篇文章主要为大家详细介绍了利用MultipartFile实现文件上传功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Java编程实现NBA赛事接口调用实例代码

这篇文章主要介绍了Java编程实现NBA赛事接口调用实例代码,具有一定参考价值,需要的朋友可以了解下。
收藏 0 赞 0 分享

Java编程之双重循环打印图形

这篇文章主要介绍了Java编程之双重循环打印图形,属于Java编程基础练习部分,具有一定参考价值,需要的朋友可以了解下。
收藏 0 赞 0 分享

java基础学习JVM中GC的算法

这篇文章主要介绍了java基础学习JVM中GC的算法,通过图文加深对GC算法思路的理解。
收藏 0 赞 0 分享

Java编程Post数据请求和接收代码详解

这篇文章主要介绍了Java编程Post数据请求和接收代码详解,涉及enctype的三种编码,post与get等相关内容,具有一定参考价值,需要的朋友可以了解下。
收藏 0 赞 0 分享

Retrofit+Rxjava实现文件上传和下载功能

这篇文章主要介绍了Retrofit+Rxjava实现文件上传和下载功能,文中提到了单文件上传和多文件上传及相关参数的请求,需要的朋友参考下吧
收藏 0 赞 0 分享

Retrofit+Rxjava下载文件进度的实现

这篇文章主要介绍了Retrofit+Rxjava下载文件进度的实现,非常不错,具有参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

java检查服务器的连通两种方法代码分享

这篇文章主要介绍了java检查服务器的连通两种方法代码分享,涉及ping的介绍以及检查服务器连通的两种方法代码示例,具有一定参考价值,需要的朋友可以了解下。
收藏 0 赞 0 分享

Java/Android 获取网络重定向文件的真实URL的示例代码

本篇文章主要介绍了Java/Android 获取网络重定向文件的真实URL的示例代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

java并发编程之同步器代码示例

这篇文章主要介绍了java并发编程之同步器代码示例,分享了相关代码,具有一定参考价值,需要的朋友可以了解下。
收藏 0 赞 0 分享
查看更多