侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

Jsp真分页实例---分页

Java  /  管理员 发布于 7年前   181

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

今天总结一个简单的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="https:/article/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="https:/article/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实现页面分页功能代码
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在java中实现的脱敏工具类代码示例分享(0个评论)
    • zookeeper安装流程步骤(0个评论)
    • 在java中你背的“八股文”可能已经过时了(2个评论)
    • 在php8.0+版本中使用属性来增加值代码示例(3个评论)
    • java 正则表达式基础,实例学习资料收集大全 原创(0个评论)
    • 近期文章
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-11
    • 2018-03
    • 2020-03
    • 2023-05
    • 2023-11
    • 2024-01
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客