springmvc 分页查询

支持数据不是很多的情况下,进行分页!

复制代码
package com.mi.controller;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;

import com.mi.form.PageTableForm;
import com.mi.service.impl.UserInfoServiceImpl;

@Controller
@RequestMapping("/user")
public class UserInfoCotroller {

    @Autowired
    private UserInfoServiceImpl userInfoServiceImpl;

    private PageTableForm pageTableForm;

    @RequestMapping("/init")
    public String init(Model model) {
        pageTableForm = new PageTableForm();
        return "redirect:/user/query.do";
    }

    @RequestMapping("/query")
    public String queryUserInfo(Model model, PageTableForm pageTableForm) {
        pageTableForm = userInfoServiceImpl.queryUserInfo(pageTableForm);
        model.addAttribute("pageTableForm", pageTableForm);
        return "userInfo";
    }

    public UserInfoServiceImpl getUserInfoServiceImpl() {
        return userInfoServiceImpl;
    }

    public void setUserInfoServiceImpl(UserInfoServiceImpl userInfoServiceImpl) {
        this.userInfoServiceImpl = userInfoServiceImpl;
    }

    public PageTableForm getPageTableForm() {
        return pageTableForm;
    }

    public void setPageTableForm(PageTableForm pageTableForm) {
        this.pageTableForm = pageTableForm;
    }

}
复制代码
复制代码
package com.mi.service.impl;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import com.mi.dao.UserInfoMapper;
import com.mi.entity.User;
import com.mi.form.PageTableForm;
import com.mi.service.UserInfoService;

@Service("userInfoService")
public class UserInfoServiceImpl implements UserInfoService {

    @Autowired
    private UserInfoMapper userInfoMapper;
    
    private List<User> userList;
    @Override
    public PageTableForm queryUserInfo(PageTableForm pageTableForm) {
        userList = userInfoMapper.queryUserInfo();
        pageTableForm.setUserList(userList);
        return pageTableForm;
    }
    

    public UserInfoMapper getUserInfoMapper() {
        return userInfoMapper;
    }
    public void setUserInfoMapper(UserInfoMapper userInfoMapper) {
        this.userInfoMapper = userInfoMapper;
    }

    @Override
    public int getCount() {
        return userInfoMapper.getCount();
    }

    public List<User> getUserList() {
        return userList;
    }

    public void setUserList(List<User> userList) {
        this.userList = userList;
    }

}
复制代码
复制代码
package com.mi.dao;

import java.util.List;

import org.springframework.stereotype.Repository;

import com.mi.entity.User;

@Repository("userInfoMapper")
public interface UserInfoMapper {
    
    public List<User> queryUserInfo();
    
    public int getCount();
}
复制代码
复制代码
package com.mi.form;

import java.util.List;

import com.mi.entity.User;

public class PageTableForm {

    private int currentPage;// 当前页
    private int pageSize = 3;// 每页记录数
    private int beginIndex;// 开始位置
    private int endIndex;// 结束位置
    private int pageCount;// 共多少页
    private int userCount;// 共多少条记录
    
    private List<User> userList;

    public int getCurrentPage() {
        return currentPage;
    }

    public void setCurrentPage(int currentPage) {
        this.currentPage = currentPage;
    }

    public int getPageSize() {
        return pageSize;
    }

    public void setPageSize(int pageSize) {
        this.pageSize = pageSize;
    }

    public int getBeginIndex() {
        return beginIndex;
    }

    public void setBeginIndex(int beginIndex) {
        this.beginIndex = beginIndex;
    }

    public int getEndIndex() {
        return endIndex;
    }

    public void setEndIndex(int endIndex) {
        this.endIndex = endIndex;
    }

    public int getPageCount() {
        return pageCount;
    }

    public void setPageCount(int pageCount) {
        this.pageCount = pageCount;
    }

    public int getUserCount() {
        return userCount;
    }

    public void setUserCount(int userCount) {
        this.userCount = userCount;
    }

    public List<User> getUserList() {
        return userList;
    }

    public void setUserList(List<User> userList) {
        this.userList = userList;
    }

}
复制代码
复制代码
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.mi.dao.UserInfoMapper">
    
    
    <select id="queryUserInfo" resultType="com.mi.entity.User">
        SELECT id,user_name userName,age FROM user_t where 1=1
    </select>
    
    <select id="getCount" resultType="int">
        SELECT count(*) FROM user_t
    </select>
    <!-- <insert id="addUser" parameterType="com.mi.entity.User"
        flushCache="true">
        INSERT INTO user_t (id,user_name,password,age) VALUES
        (#{id},#{userName},#{password},#{age})
    </insert>
    
    <delete id="deleteUser" parameterType="com.mi.entity.User" flushCache="true">
        DELETE FROM user_t where id=#{id}
    </delete>
    
    <update id="updateUser" parameterType="com.mi.entity.User" flushCache="true">
        UPDATE user_t SET user_name = 'zzxy' WHERE id=#{id}
    </update> -->
    
</mapper>
复制代码

页面+js

复制代码
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<style type="text/css">
.page{
    width:200px;
}
.page span{
    margin-left:30px;
}
a{
    text-decoration:none;
}
</style>
<script type="text/javascript"
    src="<%=request.getContextPath()%>/js/jquery-1.8.3.min.js"></script>
<script type="text/javascript">
    $(function() {
        var $table = $("table");
        var currentPage = 1;
        var pageSize = 3;
        var sumRows = $table.find("tbody tr").length;
        var sumPages = Math.ceil(sumRows/pageSize);
        
        init();
        paging(currentPage)
        
        
        $("#prev").click(function(){
            currentPage--;
            init();
            paging(currentPage);
        })
        
        $("#next").click(function(){
            currentPage++;
            init();
            paging(currentPage);
        })
        
        var $page = $("<div class='page'></div>");
        for(var pageIndex=1;pageIndex<=sumPages;pageIndex++){
            $("<a href='#'><span>["+(pageIndex)+"]</span></a>").bind("click",{"newPage":pageIndex},function(event){
                currentPage=event.data["newPage"];//值得参考
                init();
                paging(currentPage);
            }).appendTo($page);
        }
        $page.insertAfter($table);
        
        function paging(currentPage){
            $table.find("tbody tr:not(.prevnext)").hide().slice((currentPage-1)*pageSize,(currentPage)*pageSize).show();
            $("#currentPage").val(currentPage+1);
            $("#currentPage").text(currentPage);
            $("#sumPages").text(sumPages);
        }
        
        function init(){
            if(currentPage==1){
                $("#prev").attr({"disabled":"disabled"});
            }else{
                $("#prev").removeAttr("disabled");
            }
            if(currentPage==sumPages){
                $("#next").attr({"disabled":"disabled"});
            }else{
                $("#next").removeAttr("disabled");
            }
        }
        
    })
</script>
</head>
<body>
    <form action="${pageContext.request.contextPath}/user/query.do" id="form0" method="POST">
        <table border="1">
            <thead>
                <tr>
                    <td width="60px">id</td>
                    <td width="120px">name</td>
                    <td width="60px">age</td>
                </tr>
            </thead>
            <tbody>
                <c:forEach var="user" items="${pageTableForm.userList}" varStatus="status">
                    <tr>
                        <td>${user.id}</td>
                        <td>${user.userName}</td>
                        <td>${user.age}</td>
                    </tr>
                </c:forEach>
                <tr class="prevnext">
                    <td>
                        <input id="prev" type="button" value="上一页">
                    </td>
                    <td>当前<label id="currentPage"></label>页/共<label id="sumPages"></label></td>
                    <td>
                        <input id="next" type="button" value="下一页">
                    </td>
                </tr>
                
            </tbody>
        </table>
        <input id="currentPage" type="hidden" name="currentPage" value="${pageTableForm.currentPage}">
    </form>
</body>
</html>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,针对您的问题,我可以给出以下的解答: Spring MVC框架中的分页查询通常可以借助于PageHelper插件来实现。PageHelper是MyBatis分页插件,它可以拦截MyBatis的查询操作,并在查询语句执行前自动添加分页相关的语句。使用PageHelper可以帮助我们轻松地实现分页查询功能。 以下是实现Spring MVC分页查询的步骤: 1. 引入PageHelper插件依赖。 在pom.xml文件中添加以下依赖: ``` <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper</artifactId> <version>5.2.0</version> </dependency> ``` 2. 在Spring MVC配置文件中配置PageHelper插件。 在Spring MVC配置文件中添加以下配置: ``` <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource"/> <property name="plugins"> <array> <bean class="com.github.pagehelper.PageInterceptor"> <property name="properties"> <value> dialect=mysql </value> </property> </bean> </array> </property> </bean> ``` 其中,dialect属性指定数据库类型,这里以MySQL为例。 3. 在Controller中编写分页查询方法。 在Controller中编写分页查询方法,例如: ``` @RequestMapping("/list") public ModelAndView list(@RequestParam(defaultValue="1") int pageNum, @RequestParam(defaultValue="10") int pageSize) { ModelAndView mv = new ModelAndView("list"); // 使用PageHelper进行分页查询 PageHelper.startPage(pageNum, pageSize); List<User> userList = userService.getUserList(); PageInfo<User> pageInfo = new PageInfo<User>(userList); mv.addObject("userList", userList); mv.addObject("pageInfo", pageInfo); return mv; } ``` 在这个方法中,我们使用PageHelper的startPage方法开始分页查询,然后调用userService的getUserList方法获取用户列表,最后将查询结果和分页信息添加到ModelAndView中返回。 4. 在JSP页面中显示分页查询结果。 在JSP页面中显示分页查询结果,例如: ``` <table> <thead> <tr> <th>ID</th> <<th>Name</th> <th>Age</th> </tr> </thead> <tbody> <c:forEach items="${userList}" var="user"> <tr> <td>${user.id}</td> <td>${user.name}</td> <td>${user.age}</td> </tr> </c:forEach> </tbody> </table> <div> <c:if test="${pageInfo.pages > 1}"> <c:url value="/user/list" var="url"> <c:param name="pageNum" value="${pageInfo.pageNum-1}"/> </c:url> <a href="${url}">上一页</a> <c:forEach begin="1" end="${pageInfo.pages}" var="i"> <c:url value="/user/list" var="url"> <c:param name="pageNum" value="${i}"/> </c:url> <c:if test="${pageInfo.pageNum == i}"> <strong>${i}</strong> </c:if> <c:if test="${pageInfo.pageNum != i}"> <a href="${url}">${i}</a> </c:if> </c:forEach> <c:url value="/user/list" var="url"> <c:param name="pageNum" value="${pageInfo.pageNum+1}"/> </c:url> <a href="${url}">下一页</a> </c:if> </div> ``` 在这个JSP页面中,我们使用c:forEach标签遍历查询结果,使用pageInfo对象显示分页信息,使用c:url标签生成分页链接。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值