MyBatis-Plus中自带的分页操作

本文阅读 2 分钟
首页 代码,Java 正文

        相信使用过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";
    }

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

        第四步: 在浏览器中输入地址,前端效果 img

本文为互联网自动采集或经作者授权后发布,本文观点不代表立场,若侵权下架请联系我们删帖处理!文章出自:https://blog.csdn.net/qq_46540738/article/details/119518868
-- 展开阅读全文 --
安全面试之XSS(跨站脚本攻击)
« 上一篇 07-24

发表评论

成为第一个评论的人

热门文章

标签TAG

最近回复