在实际应用中,如果从数据库中查询的记录特别的多,甚至超过了显示屏的显示范围,这个时候可将结果进行分页显示。

  1. 假设总记录数为intRowCount,每页显示的数量为inPageSize,总页数为intPageCount,那么总页数的计算公式如下:
  2. 如果:(intRowCount%intPageSize)>0,则intPageCount=intRowCount/intPageSize+1
  3. 如果:(intRowCount%intPageSize)=0,则intPageCount=intRowCount/intPageSize
  4. 翻页后显示intPage页的内容,将记录指针移动到(intPage-1)*intPageSize+1

建立pageBreak.jsp文件,代码如下

  1. <%@ page import="java.sql.*" %>
  2. <%@ page contentType="text/html" pageEncoding="UTF-8" %>
  3. <html>
  4. <head>
  5. <meta http-equiv="Content-Type" content="text/html;charest=UTF-8">
  6. <title>JSP分页浏览</title>
  7. </head>
  8. <body>
  9. <div align="center">
  10. 分页显示记录内容
  11. <hr>
  12. <table border="1" bgcolor="cccfff" align="center">
  13. <tr>
  14. <th>学号</th>
  15. <th>班级</th>
  16. <th>姓名</th>
  17. <th>性别</th>
  18. <th>年龄</th>
  19. </tr>
  20. <%
  21. String DBDRIVER="org.gjt.mm.mysql.Driver";                //我用的mysql数据库
  22. String DBURL="jdbc:mysql://localhost:3306/example";
  23. String DBUSER="root";
  24. String DBPASS="mysqladmin";
  25. String sql="select * from paging";
  26. int intPageSize;  //一页显示的记录数
  27. int intRowCount;  //记录总数
  28. int intPageCount; //总页数
  29. int intPage;    //待显示页码
  30. int i;
  31. String strPage;
  32. intPageSize=5;   //设置一页显示的记录数
  33. //取得待显示页码
  34. strPage=request.getParameter("page");
  35. if(strPage==null){     //没有page这个属性
  36. intPage=1;
  37. }else{
  38. intPage=java.lang.Integer.parseInt(strPage);
  39. if(intPage<1){
  40. intPage=1;
  41. }
  42. }
  43. Connection conn=null;
  44. Statement stmt=null;
  45. ResultSet rs=null;
  46. Class.forName(DBDRIVER);
  47. conn=DriverManager.getConnection(DBURL,DBUSER,DBPASS);
  48. stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY);
  49. rs=stmt.executeQuery(sql);
  50. rs.last();     //光标指向查询结果集的最后一条记录
  51. intRowCount=rs.getRow();                //获取记录总数
  52. intPageCount=(intRowCount+intPageSize-1)/intPageSize;               //计算总页数
  53. if(intPage>intPageCount){      //调整待显示的页码
  54. intPage=intPageCount;
  55. }
  56. if(intPageCount>0){
  57. rs.absolute((intPage-1)*intPageSize+1);    //将记录指针定位在待显示页的第一天记录上
  58. }
  59. //显示数据
  60. i=0;
  61. while(i<intPageSize&&!rs.isAfterLast()){
  62. %>
  63. <tr>
  64. <td><%=rs.getString("stuNumber") %></td>        //从数据库读取记录
  65. <td><%=rs.getString("stuBanji") %></td>
  66. <td><%=rs.getString("stuName") %></td>
  67. <td><%=rs.getString("stuSex") %></td>
  68. <td><%=rs.getString("stuAge") %></td>
  69. </tr>
  70. <%
  71. rs.next();
  72. i++;
  73. }
  74. %>
  75. </table>
  76. <hr>
  77. <div align="center">
  78. 第<%=intPage %>页 共<%=intPageCount %>页
  79. <%
  80. if(intPage>1){
  81. %>
  82. <a href="pageBreak.jsp?page=<%=intPage-1%>">上一页</a>
  83. <%
  84. }       //下一页
  85. if(intPage<intPageCount){
  86. %>
  87. <a href="pageBreak.jsp?page=<%=intPage+1%>">下一页</a>
  88. <%
  89. }
  90. rs.close();
  91. stmt.close();
  92. conn.close();
  93. %>
  94. </div>
  95. </div>
  96. </body>
  97. </html>

显示结果如下:

1、

2、

3、

数据库代码为:

    1. create database example;
    2. create table paging(
    3. stuNumber  varchar(15),
    4. stuBanji  varchar(10),
    5. stuName  varchar(50),
    6. stuSex  varchar(4),
    7. stuAge  int
    8. );
    9. INSERT INTO paging(stuNumber,stuBanji,stuName,stuSex,stuAge) VALUES ('2012040101207','24010105','鲍礼彬','男',23);

JSP的分页技术的更多相关文章

  1. jsp-------------之分页技术(一)

    jsp分页技术之: 如下图:百度的喵 看上图中卡哇伊的小苗的爪子下面的数字,就是分页啦!那我们如何做出这样一个效果呢? 下面我们来逐一分解: jsp分页技术一 :  (算法) /* int pageS ...

  2. Javaweb 第15天 web练习和分页技术

    第15天 web练习和分页技术 复习day14内容: 学习新技术的思路? 分析功能的思路? 使用queryRunner操作数据库的步骤? ResultSetHandler接口常用实现类(三个重点)? ...

  3. 改进Spring中的分页技术

    Spring中有一个PagedListHolder,能够实现分页. 但此类有几个缺点: 1. 使用此类的代码比較繁琐 2. 此类存放的数据源是全部的记录集,即对于记录数为1000条的数据,即使我们仅仅 ...

  4. JAVAEE之-----MySQL分页技术(带搜索)

    需求: 为什么须要採用分页技术呢?在数据库中我们查询数据的时候,须要将数据返回到显示页面.数据库中含有大量数据,所有显示在一个页面过于太多,所以我们须要採用分页技术.每一页显示不同数据. 主要解决这个 ...

  5. Mysql学习总结(32)——MySQL分页技术详解

    1.什么是数据分页:数据分页就是将很多条记录像书本一样分页,每页显示多少行记录: 2.为什么要数据分页:当我们进行sql语句查询时,假如数据有成千上万行记录,如果在同一个页面去显示,那这个页面得有多大 ...

  6. tp中使用分页技术

    1 public function showList() { $m_ld = D ( 'guangxi_ld' ); $page = I ( 'get.p', 1 ); // 在配置中获取分页值 $p ...

  7. Servlet分页技术

    这是看韩顺平老师的servlet视频,自己动手写的,楼主看韩顺平老师的servlet是2006制作的,用的是sql server数据库,自己又用的是oracle数据库,所以怕有的同学遇到同样的问题,不 ...

  8. 分页技术之PageDataSource类

    之前给大家介绍了分页技术之Gridview控件,今天给大家介绍另外一种分页技术,采用PageDataSource类 + Repeater控件来实现. 前台只需要拖出一个Repeater控件来绑定要显示 ...

  9. 分页技术之GridView控件

    GridView控件实现分页技术 第一步:设置GridView控件的属性,跟分页相关的属性设置如下: AllowPaging="true":允许分页, PageSize=" ...

随机推荐

  1. java并发等待条件的实现原理(Condition)

    本篇继续学习AQS中的另外一个内容-Condition.想必学过java的都知道Object.wait和Object.notify,同时也应该知晓这两个方法的使用离不开synchronized关键字. ...

  2. 正则表达式re.sub替换不完整的问题现象及其根本原因

    title: 正则表达式re.sub替换不完整的问题现象及其根本原因 toc: true comment: true date: 2018-08-27 21:48:22 tags: ["Py ...

  3. Django之前后端交互使用ajax的方式

    1. 在项目中前后端数据相互是一种常态, 前后端交互使用的是ajax请求和form表单的请求两种方式" ajax与form表单的区别在于: form 是整个页面刷新提交的,  但是ajax ...

  4. python_06 函数、全局变量与局部变量、函数递归

    函数 1.函数的定义: def 函数名(参数): #解释函数的功能 代码块 返回值 函数的定义主要有如下要点: def:表示函数的关键字 函数名:函数的名称,日后根据函数名调用函数 函数体:函数中进行 ...

  5. win10 下安装 neo4j(转)

    1.neo4j介绍 neo4j是基于Java语言编写图形数据库.图是一组节点和连接这些节点的关系.图形数据库也被称为图形数据库管理系统或GDBMS.详细介绍可看Neo4j 教程 2.安装Java jd ...

  6. window.location.href 页面不跳转解决

    function login() { var userid = $("#username").val(); var userpwd = $("#pwd").va ...

  7. VueJs相关学习网址

      麦子学院 http://www.maiziedu.com/course/916/   慕课网-vue.js入门基础 https://www.imooc.com/learn/694   查阅的网址 ...

  8. java集合框架(1) hashMap 简单使用以及深度分析(转)

    java.util 类 HashMap<K,V>java.lang.Object  java.util.AbstractMap<K,V>      java.util.Hash ...

  9. Windows server 2012 R2 解决“无法完成域加入,原因是试图加入的域的SID与本计算机的SID相同

    Windows server 2012 R2 解决“无法完成域加入,原因是试图加入的域的SID与本计算机的SID相同.”使用克隆的系统时,加域是出现如下问题.“无法完成域加入,原因是试图加入的域的SI ...

  10. 网站开发,推荐使用SuperSlide 插件-Tab标签切换,图片滚动,无缝滚动,焦点图

    SuperSlide 致力于解决网站大部分特效展示问题,使网站代码规范整洁,方便维护更新.网站上常用的“焦点图/幻灯片”“Tab标签切换”“图片滚动”“无缝滚动”等只需要一个SuperSlide即可解 ...