首页 > 程序开发 > Web开发 > Jsp >

JAVA/JSP学习系列之六(MySQL翻页例子)

2008-05-21

一、运行前准备    下载了MySQL(和PHP搭配之最佳组合)的jdbc驱动(一个jar文件)并加载在CLASSPATH(方法见《JAVA/jsp(SUN企业级应用的首选)学习系列之一(JDK安装) 》)   (如果找不到,请从本站下载)   建一个MySQL(和PHP搭配之最佳

一、运行前准备

   下载了MySQL(和PHP搭配之最佳组合)的jdbc驱动(一个jar文件)并加载在CLASSPATH(方法见《JAVA/jsp(SUN企业级应用的首选)学习系列之一(JDK安装) 》)

   (如果找不到,请从本站下载)

   建一个MySQL(和PHP搭配之最佳组合)数据库test

   数据库中有一个表:note,字段为:name(varchar)

二、下载,安装

<%@ page contentType="text/html;charset=gb2312" %>

<% 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 = 2;

//取得待显示页码

strPage = request.getParameter("page");

if(strPage==null)&#123;

//表明在QueryString中没有page这一个参数,此时显示第一页数据

intPage = 1;

&#125; else&#123;

//将字符串转换成整型

intPage = java.lang.Integer.parseInt(strPage);

if(intPage<1) intPage = 1;

&#125;

//装载JDBC驱动程序

Class.forName("org.gjt.mm.MySQL(和PHP搭配之最佳组合).Driver").newInstance();

//连接数据库

sqlCon= java.sql.DriverManager.getConnection("jdbc:MySQL(和PHP搭配之最佳组合)://localhost/test");

//创建语句对象

sqlStmt = sqlCon.createStatement(java.sql.ResultSet.TYPE_SCROLL_INSENSITIVE,java.sql.ResultSet.CONCUR_READ_ONLY); //执行SQL语句

strSQL = "select name from note";

//执行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(SUN企业级应用的首选)数据库操作例程 - 数据分页显示 - JDBC 2.0 - MySQL(和PHP搭配之最佳组合)</title>

</head>

<body>

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

<tr>

<th>姓名</th>

</tr>

<% if(intPageCount>0)

&#123;

//将记录指针定位到待显示页的第一条记录上

sqlRst.absolute((intPage-1) * intPageSize + 1);

//显示数据

i = 0;

while(i<intPageSize && !sqlRst.isAfterLast())&#123; %>

<tr>

<td>

<%=sqlRst.getString(1)%>

</td>

</tr>

<% sqlRst.next();

i++;

&#125;

&#125;

%>

</table>

第<%=intPage%>页 共<%=intPageCount%>页

<%if(intPage<intPageCount)&#123;%><a href="MySQL(和PHP搭配之最佳组合)page.jsp(SUN企业级应用的首选)?page=<%=intPage+1%>">下一页</a><%&#125;%>

<%if(intPage>1)&#123;%><a href="MySQL(和PHP搭配之最佳组合)page.jsp(SUN企业级应用的首选)?page=<%=intPage-1%>">上一页</a><%&#125;%>

</body>

</html>

<%

//关闭结果集

sqlRst.close();

//关闭SQL语句对象

sqlStmt.close();

//关闭数据库

sqlCon.close();

%>

三、怎么去运行?

   见前文《JAVA/jsp(SUN企业级应用的首选)学习系列之五(JDBC-ODBC翻页例子)》。
相关文章
最新文章
热点推荐