JSP的分页技术
在实际应用中,如果从数据库中查询的记录特别的多,甚至超过了显示屏的显示范围,这个时候可将结果进行分页显示。
- 假设总记录数为intRowCount,每页显示的数量为inPageSize,总页数为intPageCount,那么总页数的计算公式如下:
- 如果:(intRowCount%intPageSize)>0,则intPageCount=intRowCount/intPageSize+1
- 如果:(intRowCount%intPageSize)=0,则intPageCount=intRowCount/intPageSize
- 翻页后显示intPage页的内容,将记录指针移动到(intPage-1)*intPageSize+1
建立pageBreak.jsp文件,代码如下
- <%@ page import="java.sql.*" %>
- <%@ page contentType="text/html" pageEncoding="UTF-8" %>
- <html>
- <head>
- <meta http-equiv="Content-Type" content="text/html;charest=UTF-8">
- <title>JSP分页浏览</title>
- </head>
- <body>
- <div align="center">
- 分页显示记录内容
- <hr>
- <table border="1" bgcolor="cccfff" align="center">
- <tr>
- <th>学号</th>
- <th>班级</th>
- <th>姓名</th>
- <th>性别</th>
- <th>年龄</th>
- </tr>
- <%
- String DBDRIVER="org.gjt.mm.mysql.Driver"; //我用的mysql数据库
- String DBURL="jdbc:mysql://localhost:3306/example";
- String DBUSER="root";
- String DBPASS="mysqladmin";
- String sql="select * from paging";
- int intPageSize; //一页显示的记录数
- int intRowCount; //记录总数
- int intPageCount; //总页数
- int intPage; //待显示页码
- int i;
- String strPage;
- intPageSize=5; //设置一页显示的记录数
- //取得待显示页码
- strPage=request.getParameter("page");
- if(strPage==null){ //没有page这个属性
- intPage=1;
- }else{
- intPage=java.lang.Integer.parseInt(strPage);
- if(intPage<1){
- intPage=1;
- }
- }
- Connection conn=null;
- Statement stmt=null;
- ResultSet rs=null;
- Class.forName(DBDRIVER);
- conn=DriverManager.getConnection(DBURL,DBUSER,DBPASS);
- stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY);
- rs=stmt.executeQuery(sql);
- rs.last(); //光标指向查询结果集的最后一条记录
- intRowCount=rs.getRow(); //获取记录总数
- intPageCount=(intRowCount+intPageSize-1)/intPageSize; //计算总页数
- if(intPage>intPageCount){ //调整待显示的页码
- intPage=intPageCount;
- }
- if(intPageCount>0){
- rs.absolute((intPage-1)*intPageSize+1); //将记录指针定位在待显示页的第一天记录上
- }
- //显示数据
- i=0;
- while(i<intPageSize&&!rs.isAfterLast()){
- %>
- <tr>
- <td><%=rs.getString("stuNumber") %></td> //从数据库读取记录
- <td><%=rs.getString("stuBanji") %></td>
- <td><%=rs.getString("stuName") %></td>
- <td><%=rs.getString("stuSex") %></td>
- <td><%=rs.getString("stuAge") %></td>
- </tr>
- <%
- rs.next();
- i++;
- }
- %>
- </table>
- <hr>
- <div align="center">
- 第<%=intPage %>页 共<%=intPageCount %>页
- <%
- if(intPage>1){
- %>
- <a href="pageBreak.jsp?page=<%=intPage-1%>">上一页</a>
- <%
- } //下一页
- if(intPage<intPageCount){
- %>
- <a href="pageBreak.jsp?page=<%=intPage+1%>">下一页</a>
- <%
- }
- rs.close();
- stmt.close();
- conn.close();
- %>
- </div>
- </div>
- </body>
- </html>
显示结果如下:
1、
2、
3、
数据库代码为:
- create database example;
- create table paging(
- stuNumber varchar(15),
- stuBanji varchar(10),
- stuName varchar(50),
- stuSex varchar(4),
- stuAge int
- );
- INSERT INTO paging(stuNumber,stuBanji,stuName,stuSex,stuAge) VALUES ('2012040101207','24010105','鲍礼彬','男',23);
JSP的分页技术的更多相关文章
- jsp-------------之分页技术(一)
jsp分页技术之: 如下图:百度的喵 看上图中卡哇伊的小苗的爪子下面的数字,就是分页啦!那我们如何做出这样一个效果呢? 下面我们来逐一分解: jsp分页技术一 : (算法) /* int pageS ...
- Javaweb 第15天 web练习和分页技术
第15天 web练习和分页技术 复习day14内容: 学习新技术的思路? 分析功能的思路? 使用queryRunner操作数据库的步骤? ResultSetHandler接口常用实现类(三个重点)? ...
- 改进Spring中的分页技术
Spring中有一个PagedListHolder,能够实现分页. 但此类有几个缺点: 1. 使用此类的代码比較繁琐 2. 此类存放的数据源是全部的记录集,即对于记录数为1000条的数据,即使我们仅仅 ...
- JAVAEE之-----MySQL分页技术(带搜索)
需求: 为什么须要採用分页技术呢?在数据库中我们查询数据的时候,须要将数据返回到显示页面.数据库中含有大量数据,所有显示在一个页面过于太多,所以我们须要採用分页技术.每一页显示不同数据. 主要解决这个 ...
- Mysql学习总结(32)——MySQL分页技术详解
1.什么是数据分页:数据分页就是将很多条记录像书本一样分页,每页显示多少行记录: 2.为什么要数据分页:当我们进行sql语句查询时,假如数据有成千上万行记录,如果在同一个页面去显示,那这个页面得有多大 ...
- tp中使用分页技术
1 public function showList() { $m_ld = D ( 'guangxi_ld' ); $page = I ( 'get.p', 1 ); // 在配置中获取分页值 $p ...
- Servlet分页技术
这是看韩顺平老师的servlet视频,自己动手写的,楼主看韩顺平老师的servlet是2006制作的,用的是sql server数据库,自己又用的是oracle数据库,所以怕有的同学遇到同样的问题,不 ...
- 分页技术之PageDataSource类
之前给大家介绍了分页技术之Gridview控件,今天给大家介绍另外一种分页技术,采用PageDataSource类 + Repeater控件来实现. 前台只需要拖出一个Repeater控件来绑定要显示 ...
- 分页技术之GridView控件
GridView控件实现分页技术 第一步:设置GridView控件的属性,跟分页相关的属性设置如下: AllowPaging="true":允许分页, PageSize=" ...
随机推荐
- Servlet-知识点
2018年10月05日 16:52:56 yigg 阅读数:38 1.JavaWeb开发的目录结构 https://blog.csdn.net/u012661010/article/details ...
- Mysql相关问题集锦
1:连接阿里云的服务器时,用navicate连接SSH时提示:或提示指到另一个IP从而进不去. SSH:expected key exchange group packet form server 解 ...
- leetcode11
public class Solution { //public int MaxArea(int[] height) //{ // var max = 0; // for (int i = 0; i ...
- sql server 查看锁表SQL【转】
1.select * from sys.dm_tran_locks或sp_LOCK 查看request_node 字段中为'X'(排他锁)或'IX'(意向排他锁)2.用sp_who2 + pid(进程 ...
- pynlpir 报错 Cannot Save user dictionary 原因与解决方法
在使用pynlpir和用户自定义词典进行分词时,如果报出如下错误: [2017-12-09 18:05:51] Cannot Save user dictionary Cannot write log ...
- ArcGIS自定义工具箱-字段分割
ArcGIS自定义工具箱-字段分割 联系方式:谢老师,135-4855-4328,xiexiaokui#qq.com 目的:用指定分割符分割字段, 用例:湖南省长沙市=>湖南/长沙 数据源: 使 ...
- 《CSAPP》 可重定位目标文件格式
可重定位目标文件 ELF文件 ELF头以一个16字节的序列开始,这个序列描述了生成该文件的系统的字的大小和字节顺序.ELF头剩下的部分包含帮助链接器语法分析和解释目标文件的信息.其中包括ELF头的大小 ...
- 高级编程T-SQL函数
--字符串函数--1.LEN:返回一个字符串的字符数select LEN('中国'),LEN('abc123!')select LEN('abc '+'1'),LEN(' abc')--2.DataL ...
- 567. Permutation in String判断某字符串中是否存在另一个字符串的Permutation
[抄题]: Given two strings s1 and s2, write a function to return true if s2 contains the permutation of ...
- PHP 实现单链表
数据结构是计算机存储.组织数据的方式,结构不同那么数据的检索方式和效率都不一样, 常用的数据结构有 数组 .栈 .队列 .链表 .树.堆 今天讲下单链表,单链表是一种链式存取的数据结构, 跟顺序链表 ...