MyBatis-Plus中自带的分页操作

        相信使用过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()表示:当前页的记录数据。"

        第四步: 在浏览器中输入地址,前端效果
在这里插入图片描述

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梦梦~~

你的鼓励是对我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值