在Java中如何使用List集合实现分页,以及模糊查询后分页

物理分页工具类

package com.yutu.garden.utils;

import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;

import java.util.ArrayList;
import java.util.List;
import java.util.stream.Collectors;

/**
 * @ClassName: PageUtils
 * @Description: 物理分页
 * @Author
 * @Date 2022/12/28
 * @Version 1.0
 */
public class PageUtils {

	/**
	 * 物理分页
	 * @param list 数据
	 * @param current 当前页
	 * @param size 页码长度
	 * @param 
	 * @return
	 */
	public static <T> List<T> startPage(List<T> list, Integer current, Integer size) {
		if (CollectionUtils.isEmpty(list)) {
			return list;
		}
		return list.stream().skip((current - 1) * size).limit(size).collect(Collectors.toList());
	}
}

接收参数VO类

package com.yutu.garden.vo;

import io.swagger.annotations.ApiModelProperty;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.ToString;

/**
 * @ClassName: SanitationJobStatisticsStaffParamVo
 * @Description: 人员列表请求参数
 * @Author
 * @Date 2023/8/8
 * @Version 1.0
 */
@Data
@ToString
@NoArgsConstructor
@AllArgsConstructor
public class SanitationJobStatisticsStaffParamVo {
	@ApiModelProperty("姓名")
	private String name;
	@ApiModelProperty("当前页")
	private Long current;
	@ApiModelProperty("每页的数量")
	private Long size;
}

核心代码

  • sanitationJobStatisticsStaffVoArrayList:是数据库中查出来的数据
  • sanitationJobStatisticsStaffParamVo:是接收参数VO类
//物理分页
List<SanitationJobStatisticsStaffVo> sanitationJobStatisticsStaffVosPage = PageUtils.startPage(sanitationJobStatisticsStaffVoArrayList, Integer.parseInt(sanitationJobStatisticsStaffParamVo.getCurrent().toString()), Integer.parseInt(sanitationJobStatisticsStaffParamVo.getSize().toString()));
map.put("tableData",sanitationJobStatisticsStaffVosPage);
//如果有模糊查询 则按模糊查询去分页
if (StringUtils.isNotEmpty(sanitationJobStatisticsStaffParamVo.getName())){
    //过滤 模糊查询
	List<SanitationJobStatisticsStaffVo> collectLikeSelect = sanitationJobStatisticsStaffVoArrayList.stream().filter(sanitationJobStatisticsStaffVo -> sanitationJobStatisticsStaffVo.getName().toLowerCase().contains(sanitationJobStatisticsStaffParamVo.getName().toLowerCase())).collect(Collectors.toList());
	//模糊查询后得到一个List集合,再将这个集合进行分页
	List<SanitationJobStatisticsStaffVo> sanitationJobStatisticsStaffVosLikePage = PageUtils.startPage(collectLikeSelect, Integer.parseInt(sanitationJobStatisticsStaffParamVo.getCurrent().toString()), Integer.parseInt(sanitationJobStatisticsStaffParamVo.getSize().toString()));
	map.put("tableData",sanitationJobStatisticsStaffVosLikePage);
}

你可能感兴趣的:(Java学习笔记,java,list,开发语言)