全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Jsp真分页实例---分页

网页的分页功能的实现比较简单,实现方法也多种多样。

今天总结一个简单的Jsp真分页实例。

首先,提到分页就要先明确一个概念,何为真分页何谓假分页。

假分页:一次性从数据库读出表的所有数据一次性的返回给客户端,由js来控制每一页的显示

真分页:由程序控制,每一次只返回一页大小的数据,显示到客户端

由此可以很清楚的分辨出真假分页各自的优缺点:

假分页:由于一次性读出所有数据并返回给客户端,如果数据量庞大,所以这一次的动作可能是非常消耗服务器资源和带宽的,

但是返回给客户端以后就非常轻松了,客户在一段时间内不会再像服务器端请求资源。但不代表可能出现一些意外情况,

比如说客户将浏览器关闭,重新访问网站等。所以,如果数据量相当庞大,不建议使用用真分页。

真分页:假分页每次只取需要的数据返回给客户端,比起真分页没有那么大的数据库压力。但也因为这个工作特性,所以假分页

的方法需要频繁和服务器端进行交互。既然频繁交互,自然也会给服务器带来负担。

综上:如果数据量较小,使用假分页的效果会更优,如果数据量庞大,使用真分页的效果更优。

分析完特性,下面就来列举一个简单的真分页实例。

真分页是通过程序来控制的,每次向数据库请求需要的数据。

简述实现思路业务流程:

首先:客户端带着page参数请求客户端,若没有带page参数,说明是第一次访问,则page参数默认为0;

其次:服务端根据page参数,调用相关函数,从数据库中取出表中数据,封装成相关对象,返回给客户端,并且返回新page参数及总页数;

最后:再客户端显示请求的相关数据,并根据page参数及总页数两个参数,决定上一页下一页的按钮是否可用。

数据库操作类:

public class DBBean {
  private Connection con;

  private PreparedStatement pstmt;
  private ResultSet rs;
  private String dbName ="test";
  private String dbuser = "root";
  private String dbpass ="******";
  
  static{
    try{
      Class.forName("com.mysql.jdbc.Driver");
    }catch(ClassNotFoundException e){
      System.out.println(e);
    }
    
  }
  
  public void prepareConnection(){
    try{
      con=DriverManager.getConnection("jdbc:mysql://localhost:3306/"+dbName,dbuser,dbpass);
    }catch(SQLException e){
      System.out.println(e);
    }
  }
  //关闭连接
  public void close(){
      try {
        if(con!=null)
          con.close();
      } catch (SQLException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
      }
      con = null;
      try {
        if(pstmt!=null)
          pstmt.close();
      } catch (SQLException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
      }
      pstmt = null;
  }
  //设置参数
  private void setParems(String[] parems){
    if(parems!=null){
      for(int i=0;i<parems.length;i++){
        try {
          pstmt.setString(i+1, parems[i]);
        } catch (SQLException e) {
          // TODO Auto-generated catch block
          e.printStackTrace();
        }
      }
    }
  }
  public ResultSet executeQuery(String sql,String[] parems){
    ResultSet res = null;
    prepareConnection();
    try {
      pstmt = con.prepareStatement(sql);
      setParems(parems);
      res = pstmt.executeQuery();
    } catch (SQLException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
    }finally{
     }
    return res;
  }
}

学生类:

public class StudentBean {
  private long id;
  private String name;
  private String phone;
  private int age;
  private int score;
  public long getId() {
    return id;
  }
  public void setId(long id) {
    this.id = id;
  }
  public String getName() {
    return name;
  }
  public void setName(String name) {
    this.name = name;
  }
  public String getPhone() {
    return phone;
  }
  public void setPhone(String phone) {
    this.phone = phone;
  }
  public int getAge() {
    return age;
  }
  public void setAge(int age) {
    this.age = age;
  }
  public int getScore() {
    return score;
  }
  public void setScore(int score) {
    this.score = score;
  }
}

学生数据操作类

public class StudentDao implements StudentDaoIn {
@Override 
public ArrayList<StudentBean> findByPage(int page){
    DBBean db = new DBBean();
    int begin = (page-1) * 5;
    String sql = "select * from t_student limit "+begin+",5";
    ResultSet rs = db.executeQuery(sql,null);
    ArrayList<StudentBean> list = new ArrayList<StudentBean>();
    try {
      while(rs.next()){
        StudentBean st = new StudentBean();
        st.setName(rs.getString("name"));
        st.setAge(rs.getInt("age"));
        st.setId(rs.getInt("id"));
        st.setPhone(rs.getString("phnoe"));
        st.setScore(rs.getInt("score"));
        list.add(st);
      }
    } catch (SQLException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
    }
    return list;
  }
  @Override 
  public int userCount(){
    DBBean db = new DBBean();
    String sql = "select count(*) from t_student";
    ResultSet rs = db.executeQuery(sql, null);
    int count = 0;
    try {
      rs.next();
      count = rs.getInt(1);
    } catch (SQLException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
    }
    return count;
  }
}

相关业务逻辑

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    // TODO Auto-generated method stub
    String page = null;
    page = request.getParameter("page");
    if(page == null || page=="")
      page = "1";
    StudentDao studao = new StudentDao();
    request.setAttribute("student",studao.findByPage(Integer.parseInt(page)));
    request.setAttribute("pagenum",studao.userCount()/5+1);//总页数
    request.setAttribute("page", page);//当前页
    request.getRequestDispatcher("student.jsp").forward(request, response);  
    
  }

前台JSP代码:

<table id="t_stu" border="1" cellpadding="2" cellspacing="0">
  <thead>
    <tr>
      <th>ID</th>
      <th>姓名</th>
      <th>年龄</th>
      <th>电话</th>
      <th>成绩</th>
    </tr>
  </thead>
  <c:forEach items="${student}" var="st">
    <tr>
      <td>${st.getId()}</td>
      <td>${st.getName()}</td>
      <td>${st.getAge()}</td>
      <td>${st.getPhone()}</td>
      <td>${st.getScore()}</td>
    </tr>
  </c:forEach>
</table>
<br>
共 ${pagenum}页  当前 第${page}页 
<c:choose>
  <c:when test="${page>1}">
    <a href="getSutent?page=${page-1}" rel="external nofollow" ><input type="button" value="上一页" ></a>
  </c:when>
  <c:otherwise>
    <input type="button" value="上一页" disabled="disabled" />
  </c:otherwise>
</c:choose>
<c:choose>
  <c:when test="${page!=pagenum}">
    <a href="getSutent?page=${page+1}" rel="external nofollow" ><input type="button" value="下一页"></a>
  </c:when>
  <c:otherwise>
    <input type="button" value="下一页" disabled="disabled" />
  </c:otherwise>
</c:choose>

本例是真分页的一个简单实现,有着明显的缺点。

例如:

1.在后台相关业务逻辑处,只对page做了简单的判断,因为查询相关page时,参数是写入前台a标签中的,所以懂技术的用户,可以随意改动其值

由此查询数据库可能带来意想不到的错误。

2.功能不够完善,仅提供了上一页下一页按钮的简单功能。

另外:实现假分页时可以结合ajax和json。以此可实现无刷新翻页,看起来功能和真分页一样。。。


# Jsp  # 真分页  # jsp分页显示的实现代码  # JSP分页显示的实例代码  # jsp实现上一页下一页翻页功能(示例代码)  # 分页  # 客户端  # 下一页  # 上一页  # 带着  # 时间内  # 但也  # 多种多样  # 很清楚  # 会给  # 要先  # 就来  # 较小  # 松了  # 那么大  # 但不  # 会再  # 只对  # 可能出现  # 数据库中 


相关文章: 宠物网站制作html代码,有没有专门介绍宠物如何养的网站啊?  Python lxml的etree和ElementTree有什么区别  智能起名网站制作软件有哪些,制作logo的软件?  制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?  ppt在线制作免费网站推荐,有什么下载免费的ppt模板网站?  如何在建站之星绑定自定义域名?  小自动建站系统:AI智能生成+拖拽模板,多端适配一键搭建  如何高效搭建专业期货交易平台网站?  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  建站之星后台管理如何实现高效配置?  焦点电影公司作品,电影焦点结局是什么?  如何通过虚拟主机快速完成网站搭建?  如何选择适合PHP云建站的开源框架?  网站制作外包价格怎么算,招聘网站上写的“外包”是什么意思?  建站之星如何助力企业快速打造五合一网站?  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  MySQL查询结果复制到新表的方法(更新、插入)  C++用Dijkstra(迪杰斯特拉)算法求最短路径  学校免费自助建站系统:智能生成+拖拽设计+多端适配  音响网站制作视频教程,隆霸音响官方网站?  如何通过云梦建站系统实现SEO快速优化?  美食网站链接制作教程视频,哪个教做美食的网站比较专业点?  网站制作中优化长尾关键字挖掘的技巧,建一个视频网站需要多少钱?  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  GML (Geography Markup Language)是什么,它如何用XML来表示地理空间信息?  如何在自有机房高效搭建专业网站?  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  建站之星上传入口如何快速找到?  建站主机如何选?高性价比方案全解析  javascript中对象的定义、使用以及对象和原型链操作小结  定制建站策划方案_专业建站与网站建设方案一站式指南  如何通过主机屋免费建站教程十分钟搭建网站?  如何确保西部建站助手FTP传输的安全性?  C#怎么创建控制台应用 C# Console App项目创建方法  网站制作和推广的区别,想自己建立一个网站做推广,有什么快捷方法马上做好一个网站?  购物网站制作公司有哪些,哪个购物网站比较好?  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?  个人摄影网站制作流程,摄影爱好者都去什么网站?  济南网站建设制作公司,室内设计网站一般都有哪些功能?  网站网页制作专业公司,怎样制作自己的网页?  东莞专业制作网站的公司,东莞大学生网的网址是什么?  如何用虚拟主机快速搭建网站?详细步骤解析  如何在IIS服务器上快速部署高效网站?  ,制作一个手机app网站要多少钱?  如何用低价快速搭建高质量网站?  如何快速上传自定义模板至建站之星?  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  建站之星北京办公室:智能建站系统与小程序生成方案解析  Bpmn 2.0的XML文件怎么画流程图  大连 网站制作,大连天途有线官网? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。