当前位置: 代码迷 >> Java Web开发 >> 关于分页显示的有关问题
  详细解决方案

关于分页显示的有关问题

热度:22   发布时间:2016-04-17 10:34:55.0
关于分页显示的问题
这两天我做了一个人事管理系统,其中有一部门是对员工和部门进行CRUD操作,现在有个问题不知怎么解决了。在未分页之前,CRUD都没问题,但是在分页之后只有分页的功能能实现,修改和添加不能用了。是这样的,我用的是jsp+servlet+mySQL。当要显示所有员工信息时,在servlet中调用dao的一个函数显示所有员工信息,传入一个当前页号参数currentPageNum,假如页面大小为5,没问题,分页成功显示,但是当我去修改某员工信息的时候,提交到servlet时就必须传入该条记录所在的页号,这个页号怎么计算?而且还要考虑到,如果员工的编号用1,2,3,。。。没问题,用员工id/5+1就可以得到该条记录所在的页号,但假如员工编号不是从1开始,比如1001,那该怎么计算?假如员工编号不是按序的,如1,2,4,6,。。。又该怎么得到该条记录所在的页号?因为修改后我需要看到该条记录在当前页号的新信息。当然,我也可以不这么做,直接跳到另外一个界面,比如修改成功的界面,但这样就不太友好了不是。请教各位老大给予解决,或者更好的分页方法。

------解决方案--------------------
你这分页时用的操作就有点问题,导致以后出现难题。。。
------解决方案--------------------
我用分页不是把页号作为数据记录的一项,是把数据取出来然后根据每页显示的条数计算出来有多少页,我的方法参考下吧,不知道是不是你想要的结果:
Java code
ListAction.javapackage com.sy.action;import java.util.List;import com.opensymphony.xwork2.ActionSupport;import com.sy.dao.AdminDao;import com.sy.dao.NewsDao;import com.sy.dao.impl.AdminDaoImpl;import com.sy.dao.impl.NewsDaoImpl;import com.sy.vo.Admin;import com.sy.vo.News;public class ListAction extends ActionSupport {    private static final long serialVersionUID = 1L;        int i=1;//中间变量    private int k;//储存最大页面数    private int pageNow=1; //页码数,初始为1    private int pageSize = 5 ; //页面行数     private int intRowCount;//总行数    private int intPageCount;//总页数    private Admin admin;    private List<Admin> Adminss;    private News news;    @SuppressWarnings("unchecked")    private List<News> Newss;        private int id;    private int aid;    public News getNews() {        return news;    }    public void setNews(News news) {        this.news = news;    }    @SuppressWarnings("unchecked")    public List<News> getNewss() {        return Newss;    }    public void setNewss(List<News> newss) {        Newss = newss;    }    public int getId() {        return id;    }    public void setId(int id) {        this.id = id;    }    public Admin getAdmin() {        return admin;    }    public void setAdmin(Admin admin) {        this.admin = admin;    }    public List<Admin> getAdminss() {        return Adminss;    }    public void setAdminss(List<Admin> adminss) {        Adminss = adminss;    }    public int getAid() {        return aid;    }    public void setAid(int aid) {        this.aid = aid;    }    public int getPageNow() {        return pageNow;    }    public void setPageNow(int pageNow) {        this.pageNow = pageNow;    }    public int getPageSize() {        return pageSize;    }    public void setPageSize(int pageSize) {        this.pageSize = pageSize;    }    public int getIntRowCount() {        return intRowCount;    }    public void setIntRowCount(int intRowCount) {        this.intRowCount = intRowCount;    }    public int getIntPageCount() {        return intPageCount;    }    public void setIntPageCount(int intPageCount) {        this.intPageCount = intPageCount;    }    public int getK() {        return k;    }    public void setK(int k) {        this.k = k;    }@SuppressWarnings("unchecked")    @Override//显示新闻列表    public String execute() throws Exception {        NewsDao npage=new NewsDaoImpl();        intRowCount=npage.count();        k=(intRowCount + pageSize - 1) / pageSize;        intPageCount = (intRowCount + pageSize - 1) / pageSize;//计算出总页数        if(pageNow<1){            pageNow=1;        }                if(pageNow > intPageCount)             pageNow=intPageCount;             i = (pageNow -1)*pageSize;        NewsDao nlist=new NewsDaoImpl();        if(null!=nlist.queryByPage(i,pageSize)){        Newss = nlist.queryByPage(i,pageSize);            return SUCCESS;        }else{            return "failure";        }    }          ..}listNews.jsp<%@ page language="java" pageEncoding="UTF-8"%><%@ taglib prefix="s" uri="/struts-tags"%><%    String path = request.getContextPath();    String basePath = request.getScheme() + "://"            + request.getServerName() + ":" + request.getServerPort()            + path + "/";%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"><html>    <head>        <base href="<%=basePath%>">        <title>My JSP 'index.jsp' starting page</title>    </head>    <body>..        <center>        共<s:property value="intRowCount"/>记录&nbsp;&nbsp;        第<s:property value="pageNow"/>页&nbsp;&nbsp;         <s:url id="url_pre" value="list.action">            <s:param name="pageNow" value="pageNow-1"></s:param>        </s:url>          <s:url id="url_next" value="list.action">            <s:param name="pageNow" value="pageNow+1"></s:param>        </s:url>        <s:iterator value="Newss" status="status">           <s:url id="url" value="list.action">               <s:param name="pageNow" value="pageNow"/>           </s:url>        </s:iterator>         <s:if test="pageNow==1">    <s:a href="%{url_pre}">最前一页</s:a>     </s:if>     <s:else>     <s:a href="%{url_pre}">上一页</s:a>     </s:else>     <s:if test="pageNow==k">     <s:a href="%{url_next}">最后一页</s:a>       </s:if>       <s:else>       <s:a href="%{url_next}">下一页</s:a>       </s:else>       </center>    </body></html>NewsDao.javapackage com.sy.dao.impl;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.text.SimpleDateFormat;import java.util.ArrayList;import java.util.List;import com.sy.dao.NewsDao;import com.sy.util.DataBaseConnection;import com.sy.util.StringUtil;import com.sy.vo.News;public class NewsDaoImpl implements NewsDao {                          //获取分页新闻列表    @SuppressWarnings("unchecked")    public List<News> queryByPage(int i,int pageSize){        List<News> newss=new ArrayList();                PreparedStatement pstmt    = null ;        String sql                = null ;        ResultSet rs            = null ;        DataBaseConnection dbc    = null ;        dbc = new DataBaseConnection() ;        sql = "select * from struts2new order by id asc limit " + i + "," + pageSize;        try        {                                pstmt = dbc.getConnection().prepareStatement(sql);                        rs = pstmt.executeQuery() ;            while(rs.next())            {                News news=new News();                news.setId(rs.getInt("id"));                news.setName(rs.getString("name"));                news.setTitle(rs.getString("title"));                news.setDate(rs.getString("date"));                news.setEmail(rs.getString("email"));                news.setContent(rs.getString("content"));                i++;                newss.add(news);            }            rs.close() ;            pstmt.close() ;        }        catch(Exception e)        {            System.out.println(e) ;        }        finally        {            dbc.close();        }        return newss;    }             //查询总行数    public int count() {        int intRowCount = 0;//总行数        PreparedStatement pstmt    = null ;        String sql                = null ;        ResultSet rs            = null ;        DataBaseConnection dbc    = null ;        dbc = new DataBaseConnection() ;        sql = "select count(id) from struts2new order by id asc";        try        {                        pstmt = dbc.getConnection().prepareStatement(sql);            rs = pstmt.executeQuery();            rs.next();//游标指向第一行            intRowCount=rs.getInt(1);//取得总行数            rs.close() ;            pstmt.close() ;        }        catch(Exception e)        {            System.out.println(e) ;        }        finally        {            dbc.close();        }        return intRowCount;    }}
  相关解决方案