相信使用过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 版权协议,转载请附上原文出处链接和本声明。