MyBatis-Plus中自带的分页操作

  • Post author:
  • Post category:其他



相信使用过MyBatisPlus过的同志们,肯定都知道plus在MyBatis的基础上更新了自带的分页操作。今天我们来聊一聊plus中自带的分页的具体操作。




第一步:

导入依赖

<!--        MyBatis-Plus的依赖-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.4.1</version>
        </dependency>



第二步:

写配置类

@Configuration      //表示这是一个配置类
public class MybatisPlusPageConfig {

    /**
     * 注册插件
     */
    @Bean   //表示此方法返回一个Bean实例
    public MybatisPlusInterceptor mybatisPlusInterceptor(){
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        //添加分页插件
        PaginationInnerInterceptor pageInterceptor = new PaginationInnerInterceptor();
        //设置请求的页面大于最大页的操作,true调回首页,false继续请求,默认是false
        pageInterceptor.setOverflow(false);
        //单页分页的条数限制,默认五限制
        pageInterceptor.setMaxLimit(500L);
        //设置数据库类型
        pageInterceptor.setDbType(DbType.MYSQL);

        interceptor.addInnerInterceptor(pageInterceptor);
        return interceptor;
    }
}



第三步:

编写代码

/**
	 * 查询用户列表
	 * @param model
	 * @param queryRealName
	 * @param queryRoleId
	 * @param pageIndex
	 * @return
	 */
	@RequestMapping(value="/list")
	public String getUserList(Model model
			, @RequestParam(value="queryRealName",required=false) String queryRealName
			, @RequestParam(value="queryRoleId",required=false) Integer queryRoleId
			, @RequestParam(value="pageIndex",required=false, defaultValue = "1") Integer pageIndex) throws Exception {

		//总记录数
		QueryWrapper<SysUser> wrapper = new QueryWrapper<>();
		//拼接sql语句
		if(null != queryRoleId && queryRoleId != 0){
			//null需写在运算符前面,防止报空指针
			wrapper.eq("roleId",queryRoleId);
		}
		if(queryRealName != "" && queryRealName != null){
			wrapper.eq("realName",queryRealName);
		}
		int totalCount = sysUserService.count(wrapper);
		//页码
		Page<SysUser> page = new Page<>();
		page.setCurrent(pageIndex);
		page.setSize(Constants.pageSize);
		//执行分页操作,page方法返回的是一个Page对象
		Page<SysUser> userPage = sysUserService.page(page, wrapper);
		System.out.println("=============getCountId():"+userPage.getCountId());
		System.out.println("=============getSize()"+userPage.getSize());
		System.out.println("=============getCurrent()"+userPage.getCurrent());
		System.out.println("=============getPages()"+userPage.getPages());
		System.out.println("=============getRecords()"+userPage.getRecords());
		//从结果中获取记录数
		List<SysUser> userList = userPage.getRecords();
		//获取角色列表
		List<SysRole> roleList = sysRoleService.getRoleList();

		//添加模型数据
		model.addAttribute("roleList",roleList);
		model.addAttribute("userList",userList);
		model.addAttribute("queryRealName",queryRealName);
		model.addAttribute("queryRoleId",queryRoleId);
		model.addAttribute("page",userPage);
		return "sysUser/list";
	}


运行执行的结果是:


在这里插入图片描述


由上可发现,调用page()方法完成分页操作返回的Page对象,里面的getSize()方法表示:每页的个数;getCurrent()方法表示:当前页数;getPages()表示:一共有多少页;getRecords()表示:当前页的记录数据。”



第四步:

在浏览器中输入地址,前端效果


在这里插入图片描述



版权声明:本文为qq_46540738原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。