您的位置:首页 > Web前端 > JavaScript

用JSP实现的分页程序

2006-12-26 20:08 411 查看
<%@ page contentType="text/html; charset=UTF-8" %>

<%@ page import="java.sql.*"%>

<%@ page import="java.io.*"%>

<title>Jsp分页显示记录</title><body bgcolor="#ffffff">

<%

//变量声明

Connection sqlCon; //数据库连接对象

Statement sqlStmt; //SQL语句对象

ResultSet sqlRst; //结果集对象

String strCon; //数据库连接字符串

String strSQL; //SQL语句

int intPageSize; //一页显示的记录数

int intRowCount; //记录总数

int intPageCount; //总页数

int intPage; //待显示页码

String strPage;

int i;

//设置一页显示的记录数

intPageSize = 5;

//取得待显示页码

strPage = request.getParameter("page");

if(strPage==null){//表明在QueryString中没有page这一个参数,此时显示第一页数据

intPage = 1;

}

else{//将字符串转换成整型

intPage = Integer.parseInt(strPage);

if(intPage<1) intPage = 1;

}

//装载JDBC驱动程序

try{

Class.forName("com.mysql.jdbc.Driver");

}

catch(ClassNotFoundException e){out.print("加载驱动错误");}

//设置数据库连接字符串

strCon = "jdbc:mysql://localhost:3306/test";;

//连接数据库

sqlCon = DriverManager.getConnection(strCon,"test","test");

//创建一个可以滚动的只读的SQL语句对象

sqlStmt = sqlCon.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY);

//准备SQL语句

strSQL = "select * from account";

//执行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 - MYSQL</title>

</head>

<body>

<table border="1" cellspacing="0" cellpadding="0">

<tr>

<th>ID</th>

<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>

<td><%=sqlRst.getString(3)%></td>

</tr>

<%

sqlRst.next();

i++;

}

}

%>

</table>

第<%=intPage%>页 共<%=intPageCount%>页 <br>
<a href="fenye.jsp?page=1">第一页</a>

<%if(intPage>1){%><a href="fenye.jsp?page=<%=intPage-1%>">上一页</a><%}%>

<%if(intPage<intPageCount){%><a href="fenye.jsp?page=<%=intPage+1%>">下一页</a><%}%>
<a href="fenye.jsp?page=<%=intPageCount%>">最后一页</a>

</body>

</html>

<%

//关闭结果集

sqlRst.close();

//关闭SQL语句对象

sqlStmt.close();

//关闭数据库

sqlCon.close();

%>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: