Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 797|回复: 0

使用纯JSP实现分页操作

[复制链接]

该用户从未签到

发表于 2011-10-18 17:11:09 | 显示全部楼层 |阅读模式
<%@   page   contentType= "text/HTML;charset=8859_1 "   %>
<%
//变量声明
java.sql.Connection   sqlCon;   //数据库连接对象
java.sql.Statement   sqlStmt;   //SQL语句对象
java.sql.ResultSet   sqlRst;   //结果集对象
java.lang.String   strCon;   //数据库连接字符串
java.lang.String   strSQL;   //SQL语句
int   intPageSize;   //一页显示的记录数
int   intRowCount;   //记录总数
int   intPageCount;   //总页数
int   intPage;   //待显示页码
java.lang.String   strPage;
int   i;
//设置一页显示的记录数
intPageSize   =   25;
//取得待显示页码
strPage   =   request.getParameter( "page ");
if(strPage==null){//表明在QueryString中没有page这一个参数,此时显示第一页数据
intPage   =   1;
}
else{//将字符串转换成整型
intPage   =   java.lang.Integer.parseInt(strPage);
if(intPage <1)   intPage   =   1;
}
//装载JDBC驱动程序

Class.forName( "sun.jdbc.odbc.JdbcOdbcDriver ");
//java.sql.DriverManager.registerDriver(new   oracle.jdbc.driver.OracleDriver());
//设置数据库连接字符串
strCon   =   "jdbcdbc:test ";
//连接数据库
sqlCon   =   java.sql.DriverManager.getConnection(strCon, "ApsuiteUser ", "uwerinfo ");
//创建一个可以滚动的只读的SQL语句对象

//sqlStmt=sqlCon.createStatement();
sqlStmt   =   sqlCon.createStatement(java.sql.ResultSet.TYPE_SCROLL_INSENSITIVE,java.sql.ResultSet.CONCUR_READ_ONLY);
//准备SQL语句
strSQL   =   "select   lsh,files   from   t_sys ";
//执行SQL语句并获取结果集
sqlRst   =   sqlStmt.executeQuery(strSQL);
//获取记录总数
sqlRst.last();
intRowCount   =   sqlRst.getRow();

//记算总页数
intPageCount   =   (intRowCount+intPageSize-1)   /   intPageSize;

//调整待显示的页码
if(intPage> intPageCount)   intPage   =   intPageCount;
%>
<html>
<head>
<meta   http-equiv= "Content-Type "   content= "text/html;   charset=gb2312 ">
<title> JSP数据库操作例程   -   数据分页显示   -   JDBC   2.0   -   Oracle </title>
</head>
<body>
<table   border= "1 "   cellspacing= "0 "   cellpadding= "0 ">
<tr>
<th> 姓名 </th>
<th> 年龄 </th>
</tr>
<%
if(intPageCount> 0){
//将记录指针定位到待显示页的第一条记录上
sqlRst.absolute((intPage-1)   *   intPageSize   +   1);
//显示数据
i   =   0;
while(i <intPageSize   &&   !sqlRst.isAfterLast()){
%>
<tr>
<td> <%=sqlRst.getString(1)%> </td>
<td> <%=sqlRst.getString(2)%> </td>
</tr>
<%
sqlRst.next();
i++;
}
}
%>
</table>
第 <%=intPage%> 页  共 <%=intPageCount%> 页   <%if(intPage <intPageCount){%> <a   href= "dbtest.jsp?page= <%=intPage+1%> "> 下一页 </a> <%}%>    <%if(intPage> 1){%> <a   href= "dbtest.jsp?page= <%=intPage-1%> "> 上一页 </a> <%}%>
</body>
</html>
<%
//关闭结果集
sqlRst.close();
//关闭SQL语句对象
sqlStmt.close();
//关闭数据库
sqlCon.close();
%>   

public   class   pageControl
{
public   int   curpage   ;   
public   int   maxpage   ;   
public   int   maxrowcount   ;   
public   int   rowsperpage   ;   


public   void   calMaxPage()   
      {      
                                  if   (this.maxrowcount   %   this.rowsperpage==0)
{
this.maxpage   =   this.maxrowcount/this.rowsperpage;
}
else
{
this.maxpage   =   this.maxrowcount/this.rowsperpage   +   1;
}
}
}
jsp中:
pageControl   pageCtl=new   pageControl();
                pageCtl.rowsperpage=10;//每页显示的行数
                int   pageNo=1;

                if   (request.getParameter( "page ")!=null)   
{
                              pageNo=Integer.parseInt(request.getParameter( "page "));
                        }

                pageCtl.curpage=pageNo;//当前页
        pageCtl.maxrowcount=从数据库中取得的要显示出来的记录数
          pageCtl.calMaxPage();//调用方法
  <%if(pageCtl.curpage==1){   out.print( "   首页   上一页 ");       }else{     %>
        <A   HREF= " <%=global_usermanage%> ?flag= <%=flag%> &userid1= <%=userid1%> "> 首页 </A>   <A   HREF= " <%=global_usermanage%> ?page= <%=pageCtl.curpage-1%> &flag= <%=flag%> &userid1= <%=userid1%> "> 上一页 </A>
        <%}%>
        <%if(pageCtl.curpage==pageCtl.maxpage){   out.print( "下一页   尾页 ");       }else{     %>
        <A   HREF= " <%=global_usermanage%> ?page= <%=pageCtl.curpage+1%> &flag= <%=flag%> &userid1= <%=userid1%> "> 下一页 </A>   <A   HREF= " <%=global_usermanage%> ?page= <%=pageCtl.maxpage%> &flag= <%=flag%> &userid1= <%=userid1%> "> 尾页 </A>
        <%}%>
        每页 <%=pageCtl.rowsperpage%> 行   共 <%=pageCtl.maxrowcount%> 行   第 <%=pageCtl.curpage%> 页
        共 <%=pageCtl.maxpage%> 页
//over
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

GMT+8, 2024-5-18 15:25 , Processed in 0.415946 second(s), 48 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表