SSM框架+bootstrap+PageHelper分页

本文介绍了如何在SSM框架下结合PageHelper进行分页操作。首先,通过导入PageHelper包并配置到Spring和MyBatis的配置文件中。接着,使用PageHelper.startPage静态方法设置分页参数,此方法会自动对后续的第一个SQL查询进行分页。最后,通过PageInfo对象获取分页信息,并在Controller层将数据封装为Msg类,返回给前端。在JSP页面中展示分页结果,如果未使用Bootstrap,需提前下载。
摘要由CSDN通过智能技术生成

SSM框架搭建,点击这里

PageHelper的使用

第一步、导包(或者导入坐标)

<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>5.1.2</version> 
</dependency>

第二步、配置到spring 和mybait 整合的配置文件中

<!--3.创建sqlSessionFactory-->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"></property>
<!--配置mybatis 插件-->
<property name="plugins">
    <set>
        <!--配置pageHelper 分页插件-->
        <bean class="com.github.pagehelper.PageInterceptor">
            <property name="properties">
                <props>
                    <!--方言:-->
                    <prop key="helperDialect">mysql</prop>
                </props>
            </property>
        </bean>
    </set>
</property>
</bean>

第三步、方法调用
使用PageHelper.startPage 静态方法调用startPage :
特点:

  1. 静态方法,传递两个参数(当前页码,每页查询条数)
  2. 使用pageHelper 分页的时候,不再关注分页语句,查询全部的语句
  3. 自动的对PageHelper.startPage 方法下的第一个sql 查询进行分页
		PageHelper.startPage(page, pageSize);//顺序重要
        List<Books> emps= bookService.queryAllBook1();
        //使用pageInfo包装查询后的结果,只需将pageInfo交给页面就行了。
        //里面封装了详细的分页信息,包括有我们查询出来的数据
        PageInfo pageInfo =new PageInfo(emps);  //连续显示的页数
        model.addAttribute("pageInfo",pageInfo );

返回的信息就是pageInfo对象,该类是插件里的类,这个类里面的属性还是值得看一看

public class PageInfo<T> implements Serializable {
   
private static final long serialVersionUID = 1L;
//当前页
private int pageNum;
//每页的数量
private int pageSize;
//当前页的数量
private int size;
//由于startRow 和endRow 不常用,这里说个具体的用法
//可以在页面中"显示startRow 到endRow 共size 条数据"
//当前页面第一个元素在数据库中的行号
private int startRow;
//当前页面最后一个元素在数据库中的行号
private int endRow;
//总记录数
private long total;
//总页数
private int pages;
//结果集
private List<T> list;
//前一页
private int prePage;
//下一页
private int nextPage;
//是否为第一页
private boolean isFirstPage = false;
//是否为最后一页
private boolean isLastPage = false;
//是否有前一页
private boolean hasPreviousPage = false;
//是否有下一页
private boolean hasNextPage = false;
//导航页码数
private int navigatePages;
传智播客——专注于Java、.Net 和Php、网页平面设计工程师的培训
北京市昌平区建材城西路金燕龙办公楼一层电话:400-618-9090
//所有导航页号
private int[] navigatepageNums;
//导航条上的第一页
private int navigateFirstPage;
//导航条上的最后一页
private int navigateLastPage;
}

新建一个Msg类,用于封装返回的数据
在这里插入图片描述

package com.kuang.pojo;

import java.util.HashMap;
import java.util.Map;

/**
 * @author moon
 * @create 2021-02-21 8:41
 */
public class Msg {
   
    //状态码   返回100  代表成功  -100代表失败
    private int code;
    //提示详细信息  失败原因
    private String msg;
    //用户要返回给浏览器的数据
    private Map<String,Object> extend =new HashMap<String ,Object>();

    public static Msg success() {
      //返回成功
        Msg result=new Msg();
        result.setCode(100);
        result.setMsg("处理成功!");
        return result;
    }
    public static Msg fail() {
      //返回成功
        Msg result=new
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值