ssm-bootstarp分页查询

第一步:导入maven依赖

 <!--分页插件-->
        <dependency>
            <groupId>com.github.pagehelper</groupId>
            <artifactId>pagehelper</artifactId>
            <version>5.1.11</version>
        </dependency>

第二步:在mybatis-config中配置
必须写在 之后

 <!--分页插件-->
    <plugins>
        <plugin interceptor="com.github.pagehelper.PageInterceptor"></plugin>
    </plugins>

第三步:写一个分页的工具类

package com.aaa.until;

import com.aaa.pojo.Emp;
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;

import javax.servlet.http.HttpServletRequest;

public class PageUntil {
    //分页
    public  static  String getPageInfo(PageInfo<Emp> pageInfo, HttpServletRequest request){
       StringBuilder builder=new StringBuilder();
       //获取项目路径
        String path = request.getContextPath()+"/";
        //拼接首页
        builder.append("<a href='"+path+"fen/1'>首页</a>");
        builder.append("&nbsp;&nbsp;");
        //判断上一页 如果时第一页则显示当前页
        //isHasPreviousPage意思时是否有前一页,
        //如果有前一页就显示前一页
        if (pageInfo.isHasPreviousPage()){
            builder.append("<a href='"+path+"fen/"+pageInfo.getPrePage()+"'>上一页</a>");
            builder.append("&nbsp;&nbsp;");
        }else{
            builder.append("上一页");
            builder.append("&nbsp;&nbsp;");
        }
        //拼接页码[导航条] [1] [2]
        int[] nf = pageInfo.getNavigatepageNums();
        for (int i : nf) {
            if (i==pageInfo.getPageNum()){
                builder.append("<a style='color:red;' href='"+path+"fen/"+i+"'>"+i+"</a>");
                builder.append("&nbsp;&nbsp;");
            }
            else{
                builder.append("<a href='"+path+"fen/"+i+"'>"+i+"</a>");
                builder.append("&nbsp;&nbsp;");
            }

        }
        //拼接下一页
        if (pageInfo.isHasNextPage()){
            builder.append("<a href='"+path+"fen/"+pageInfo.getNextPage()+"'>下一页</a>");
            builder.append("&nbsp;&nbsp;");
        }else{
            builder.append("下一页");
            builder.append("&nbsp;&nbsp;");
        }
        //拼接尾页
        builder.append("<a href='"+path+"fen/"+pageInfo.getPages()+"'>尾页</a>");
        builder.append("&nbsp;&nbsp;");
        return builder.toString();

    }
}

第四步:在控制器层中编写代码

package com.aaa.controller;

import com.aaa.pojo.Emp;
import com.aaa.service.EmpService;
import com.aaa.until.PageUntil;
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;

import javax.servlet.http.HttpServletRequest;
import java.util.EnumMap;
import java.util.List;

@Controller
public class EmpController {
    @Autowired
    private EmpService empService;
    //查询
@RequestMapping("/fen/{pageNum}")
public String fenYe(Model model, @PathVariable("pageNum") Integer pageNum, HttpServletRequest request){
    // pageNum 第几页    pageSize:每页显示几条数据
    PageHelper.startPage(pageNum,2);
    List<Emp> emps = empService.queryEmp();
    PageInfo<Emp> pageInfo=new PageInfo<Emp>(emps,5);
    String pageInfo1 = PageUntil.getPageInfo(pageInfo, request);
    model.addAttribute("emps",emps);
    model.addAttribute("pageInfo1",pageInfo1);
    return  "list";
}

}

第五步:编写list.jsp 页面

<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>分页查询</title>
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/css/bootstrap.min.css">
</head>
<body>
<div class="container">
    <div class="row clearfix">
        <div class="col-md-12 column">
            <table class="table table-bordered table-hover">
                <thead>
                <tr class="info">
                    <th>编号</th>
                    <th>姓名</th>
                    <th>性别</th>
                    <th>部门</th>
                    <th>操作</th>
                </tr>
                </thead>
                <tbody>
                <c:forEach items="${emps}" var="list">
                    <tr>
                        <td  class="active">${list.eid}</td>
                        <td class="success">${list.ename}</td>
                        <td class="warning">${list.sex==0?'男':'女'}</td>
                        <td class="danger">${list.deptss.dname}</td>
                        <td>
                            <a href="${pageContext.request.contextPath}//${list.eid}">删除</a>
                            <a href="">修改</a>
                        </td>
                    </tr>
                </c:forEach>
                </tbody>
                <tfoot>
                    <tr>
                        <td colspan="5" style="text-align: center">${pageInfo1}</td>
                    </tr>
                </tfoot>
            </table>
        </div>
    </div>
</div>


</body>
</html>

效果图如下:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 SSM (Spring + SpringMVC + MyBatis) 框架中,你可以使用 MyBatis 的分页插件来实现分页查询。 首先,你需要在 MyBatis 的配置文件中启用分页插件: ``` <plugins> <plugin interceptor="org.mybatis.generator.plugins.RowBoundsPlugin"/> </plugins> ``` 然后,在你的 Mapper 接口中声明分页查询方法,并使用 MyBatis 的 RowBounds 类来进行分页: ```java public interface UserMapper { List<User> selectByPage(RowBounds rowBounds); } ``` 在你的 Service 层中,你可以调用 Mapper 接口的分页查询方法,并传入 RowBounds 对象来实现分页: ```java public class UserService { @Autowired private UserMapper userMapper; public List<User> getUsersByPage(int pageNum, int pageSize) { int offset = (pageNum - 1) * pageSize; RowBounds rowBounds = new RowBounds(offset, pageSize); return userMapper.selectByPage(rowBounds); } } ``` 在你的 Controller 层中,你可以调用 Service 层的分页查询方法,并将分页参数作为方法的参数传入: ```java public class UserController { @Autowired private UserService userService; @RequestMapping("/users") public List<User> getUsers(int pageNum, int pageSize) { return userService.getUsersByPage(pageNum, pageSize); } } ``` 你还可以使用第三方的分页插件,比如 PageHelper,它提供了更为简单分页查询方式。 ### 回答2: 在SSM框架中,实现分页查询一般需要以下几个步骤: 1. 在数据库中创建对应的数据表,保存需要查询的数据。 2. 在Spring配置文件中配置数据源,设置数据库连接信息。 3. 创建实体类(POJO),并映射到数据库中的表结构。使用注解指定表名、字段名、主键等信息。 4. 创建数据访问层接口(DAO),定义分页查询的方法。使用注解或者XML文件进行方法的映射。 5. 在数据访问层实现类中,实现分页查询的方法。使用MyBatis提供的分页插件PageHelper完成分页查询。在方法中设置分页参数,如当前页码和每页显示的数量,并调用对应的查询方法。 6. 创建业务逻辑层(Service),调用数据访问层的方法进行分页查询。 7. 在控制层(Controller)中接收分页参数,并调用业务逻辑层的方法进行分页查询。将查询结果封装成Page对象,并传递给前端页面。 8. 在前端页面使用分页插件(如Bootstrap分页插件或jQuery的分页插件)展示分页信息和查询结果。 总结:通过以上步骤,我们可以在SSM框架中实现分页查询。使用PageHelper插件可以简化分页查询的操作,提高开发效率。在分页查询时,需要注意设置分页参数,并合理利用数据库的索引等优化查询性能。 ### 回答3: 在SSM框架中,可以使用PageHelper插件实现分页查询。 首先,需要在pom.xml文件中添加PageHelper的依赖: ``` <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper</artifactId> <version>版本号</version> </dependency> ``` 然后,在Spring配置文件中配置PageHelper的插件: ``` <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <!-- 配置数据源等其他相关属性 --> <property name="plugins"> <array> <bean class="com.github.pagehelper.PageInterceptor"> <property name="properties"> <!-- 设置数据库方言为MySQL --> <value>dialect=mysql</value> </property> </bean> </array> </property> </bean> ``` 接下来,在需要进行分页查询的方法中,使用PageHelper的startPage方法来设置分页参数: ``` PageHelper.startPage(页码, 每页显示数量); ``` 然后,执行查询操作,返回的结果将变为一个分页对象,可以通过该对象获取相关的分页信息和查询结果,比如: ``` List<SomeEntity> list = someMapper.selectByExample(example); PageInfo pageInfo = new PageInfo(list); ``` 在页面上展示分页信息,可以使用PageInfo提供的相关方法,例如获取总记录数、总页数、当前页码、每页显示数量等: ``` pageInfo.getTotal() // 获取总记录数 pageInfo.getPages() // 获取总页数 pageInfo.getPageNum() // 获取当前页码 pageInfo.getPageSize() // 获取每页显示数量 ``` 同时,查询结果也包含在PageInfo对象中的列表中: ``` List<SomeEntity> resultList = pageInfo.getList(); ``` 通过以上步骤,就可以在SSM框架中实现分页查询操作了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值