如何使用JSP+MySQL创建留言本(二)

有了数据库下面就要对数据库操作读取留言了!
下面列出显示留言的主要程序

1@page import="java.sql.*"   
2import ="java.util.*"   
3import ="java.io.*"   
4contentType="text/html; charset=gb2312"   
 1<html>
 2<head>
 3<title>萍慧自由空间留言本</title>
 4<meta content="Microsoft FrontPage 4.0" name="GENERATOR"/>
 5<meta content="FrontPage.Editor.Document" name="ProgId"/>
 6<style type="text/css"><!--   
 7body { font-size: 9pt}   
 8td { font-size: 9pt}-->   
 9</style>
10</head>
11<body>
12<p align="center"><u><font face="华文新魏" size="5">萍慧自由空间留言本</font></u></p>
13<table align="center" bgcolor="#FFCCFF" border="1" bordercolordark="#6666FF" bordercolorlight="#0000FF" cellpadding="0" cellspacing="0" width="75%">
14<tr>
15<td colspan="5" height="202">   

//下面处理用户的分页请求
String string_page;
int Page,RecoderPage,RecoderRow;
try{string_page=request.getParameter("page");
}catch (NullPointerException e){string_page="";}
try{Page=Integer.parseInt(string_page);
}catch(NumberFormatException e)
{Page=0;
}

java.sql.Connection sqlConn; //数据库连接对象
java.sql.Statement sqlStmt; //语句对象
java.sql.ResultSet sqlRst; //结果集对象
//登记JDBC驱动对象
Class.forName ("org.gjt.mm.mysql.Driver").newInstance ();
//连接数据库
sqlConn= java.sql.DriverManager.getConnection ("jdbc:mysql://localhost/p","test","");
//创建语句对象
sqlStmt=sqlConn.createStatement
(java.sql.ResultSet.TYPE_SCROLL_INSENSITIVE,java.sql.ResultSet.CONCUR_READ_ONLY);
//执行Sql语句
String sqlQuery="select count() from comment";
sqlRst=sqlStmt.executeQuery (sqlQuery);
sqlRst.next();
int count=sqlRst.getInt(1); //取得总的留言记录数
if (Page&gt;=0)RecoderPage=Page;//处理页面
else RecoderPage=0-Page
10;
if (RecoderPage&gt;count/15){ RecoderPage=count/15; Page=RecoderPage; }//页面越界

RecoderRow=RecoderPage*15; //取得要显示的留言记录号
sqlQuery="select * from comment order by userid desc limit "+RecoderRow+",15;"; //一次读取15条记录
sqlRst=sqlStmt.executeQuery (sqlQuery);

总共有 =count

while (sqlRst.next()) //显示留言
{ //取得下一条记录 =sqlRst.getString("userid")

 1<table align="center" bgcolor="#CCCCFF" border="1" bordercolordark="#6666FF" bordercolorlight="#6666FF" cellpadding="1" cellspacing="1" width="95%">
 2<tr>
 3<td width="25%">昵称:```
 4=sqlRst.getString("username")
 5```</td>
 6<td width="25%">性别:```
 7=sqlRst.getString("sex")
 8```</td>
 9<td colspan="2" width="50%">地址:```
10=sqlRst.getString("address") 
11```</td>
12</tr>
13<tr>
14<td width="25%">电话:```
15=sqlRst.getString("telnumber")
16```</td>
17<td width="25%">邮编:```
18=sqlRst.getString("post")
19```</td>
20<td width="25%">OICQ:```
21=sqlRst.getString("oicq")
22```</td>
23<td width="25%">ICQ:```
24=sqlRst.getString("icq")
25```</td>
26</tr>
27<tr>
28<td colspan="2" width="50%">Email:   
29<a ```"="" email")="" href="mailto:```
30=sqlRst.getString(" title="写信给留言者">```
31=sqlRst.getString("email")
32```</a></td>
33<td colspan="2" width="50%">网址:   
34<a href="" target="_blank"></a><a ```"="" href="mailto:```
35=sqlRst.getString(" title="写信给留言者" url")="">   

=sqlRst.getString("urltitle")

1</tr>
2<tr>
3<td colspan="4"><font style="line-height: 150%;color: green">   
4留言:```
5=sqlRst.getString("comment")
6```<br/>   
7    -```
8=sqlRst.getString("time") 

(来自``` =sqlRst.getString("ip")

1</tr>
2</table>
3<hr align="center" noshade="" size="2" width="95%"/>   

}

//下面对留言进行分页
int i=count/15; //总页,每页显示15条记录
int j=i/10; //总的大页 ,没10个页面分一大页
//Page 显示的页面
int StartPage;
//int HrefPage;
if (Page&lt;0) Page=0-Page10; //10页分一次
StartPage=Page/10; //10页分一次
out.print ("[共有"+(i+1)+"页]");
//out.print ("共有"+j+"屏");
//out.print ("显示第"+Page+"页");
//out.print ("StartPage="+StartPage);
if (StartPage&gt;0)
out.print ("|<a +integer.tostring(startpage-1)+""="" href="connectmysql.jsp?page=-">前10页</a>");
for (int k=0;k&lt;10;k++)
{ int p=StartPage
10+k;
if (p&gt;i) break;
if (p==Page)
out.print ("|第"+Integer.toString(p+1)+"页");
else
out.print ("|<a +p+""="" href="connectmysql.jsp?page=">第"+Integer.toString(p+1)+"页</a>");
}
if (StartPage<j) ("|<a="" +integer.tostring(startpage+1)+""="" href="connectmysql.jsp?page=-" out.print="">后10页");
out.print ("|");

1</tr>
2</table>
3</body>   

//关闭结果集对象
sqlRst.close();
//关闭语句对象
sqlStmt.close ();
//关闭数据库连接
sqlConn.close();

1程序中的不足:   
2没有对错误进行捕捉,但是这里只为了对jsp读取Mysql数据库进行讲解。如果是用与作留言本的话一定要对错误进行处理! 我们还要留言呢?</html>
Published At
Categories with Web编程
Tagged with
comments powered by Disqus