如何使用JSP+MySQL創(chuàng)建留言本(二)
更新時(shí)間:2006年10月13日 00:00:00 作者:
有了數(shù)據(jù)庫下面就要對(duì)數(shù)據(jù)庫操作讀取留言了!
下面列出顯示留言的主要程序
<%@page import="java.sql.*"
import ="java.util.*"
import ="java.io.*"
contentType="text/html; charset=gb2312"
%>
<html>
<head>
<title>萍慧自由空間留言本</title>
<meta name="GENERATOR" content="Microsoft FrontPage 4.0">
<meta name="ProgId" content="FrontPage.Editor.Document">
<style type="text/css"><!--
body { font-size: 9pt}
td { font-size: 9pt}-->
</style>
</head>
<body>
<p align="center"><u><font size="5" face="華文新魏">萍慧自由空間留言本</font></u></p>
<table width="75%" border="1" bgcolor="#FFCCFF" bordercolorlight="#0000FF"
bordercolordark="#6666FF" cellpadding="0" cellspacing="0" align="center">
<tr>
<td colspan="5" height="202">
<%//下面處理用戶的分頁請(qǐng)求
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; //數(shù)據(jù)庫連接對(duì)象
java.sql.Statement sqlStmt; //語句對(duì)象
java.sql.ResultSet sqlRst; //結(jié)果集對(duì)象
//登記JDBC驅(qū)動(dòng)對(duì)象
Class.forName ("org.gjt.mm.mysql.Driver").newInstance ();
//連接數(shù)據(jù)庫
sqlConn= java.sql.DriverManager.getConnection ("jdbc:mysql://localhost/p","test","");
//創(chuàng)建語句對(duì)象
sqlStmt=sqlConn.createStatement
(java.sql.ResultSet.TYPE_SCROLL_INSENSITIVE,java.sql.ResultSet.CONCUR_READ_ONLY);
//執(zhí)行Sql語句
String sqlQuery="select count(*) from comment";
sqlRst=sqlStmt.executeQuery (sqlQuery);
sqlRst.next();
int count=sqlRst.getInt(1); //取得總的留言記錄數(shù)
if (Page>=0)RecoderPage=Page;//處理頁面
else RecoderPage=0-Page*10;
if (RecoderPage>count/15){ RecoderPage=count/15; Page=RecoderPage; }//頁面越界
RecoderRow=RecoderPage*15; //取得要顯示的留言記錄號(hào)
sqlQuery="select * from comment order by userid desc limit "+RecoderRow+",15;"; //一次讀取15條記錄
sqlRst=sqlStmt.executeQuery (sqlQuery);
%> 總共有<%=count%>條留言
<% while (sqlRst.next()) //顯示留言
{ //取得下一條記錄 %> 第<%=sqlRst.getString("userid")%>條
<table width="95%" border="1" cellspacing="1" cellpadding="1"
bordercolorlight="#6666FF" bordercolordark="#6666FF" bgcolor="#CCCCFF" align="center">
<tr>
<td width="25%">昵稱:<%=sqlRst.getString("username")%></td>
<td width="25%">性別:<%=sqlRst.getString("sex")%></td>
<td colspan="2" width="50%">地址:<%=sqlRst.getString("address") %></td>
</tr>
<tr>
<td width="25%">電話:<%=sqlRst.getString("telnumber")%></td>
<td width="25%">郵編:<%=sqlRst.getString("post")%></td>
<td width="25%">OICQ:<%=sqlRst.getString("oicq")%></td>
<td width="25%">ICQ:<%=sqlRst.getString("icq")%></td>
</tr>
<tr>
<td colspan="2" width="50%">Email:
<a href="mailto:<%=sqlRst.getString("email")%>" title="寫信給留言者"><%=sqlRst.getString("email")%></a></td>
<td colspan="2" width="50%">網(wǎng)址:
<a href target="_blank"></a><a href="mailto:<%=sqlRst.getString("url")%>" title="寫信給留言者">
<%=sqlRst.getString("urltitle")%></a></td>
</tr>
<tr>
<td colspan="4"><font style="line-height: 150%;color: green">
留言:<%=sqlRst.getString("comment")%><br>
-<%=sqlRst.getString("time") %>
(來自<%=sqlRst.getString("ip") %>)</font></td>
</tr>
</table>
<hr align="center" noshade size="2" width="95%">
<% } %> <%
//下面對(duì)留言進(jìn)行分頁
int i=count/15; //總頁,每頁顯示15條記錄
int j=i/10; //總的大頁 ,沒10個(gè)頁面分一大頁
//Page 顯示的頁面
int StartPage;
//int HrefPage;
if (Page<0) Page=0-Page*10; //10頁分一次
StartPage=Page/10; //10頁分一次
out.print ("[共有"+(i+1)+"頁]");
//out.print ("共有"+j+"屏");
//out.print ("顯示第"+Page+"頁");
//out.print ("StartPage="+StartPage);
if (StartPage>0)
out.print ("|<a href="connectmysql.jsp?page=-"+Integer.toString(StartPage-1)+"">前10頁</a>");
for (int k=0;k<10;k++)
{ int p=StartPage*10+k;
if (p>i) break;
if (p==Page)
out.print ("|第"+Integer.toString(p+1)+"頁");
else
out.print ("|<a href="connectmysql.jsp?page="+p+"">第"+Integer.toString(p+1)+"頁</a>");
}
if (StartPage<j)
out.print ("|<a href="connectmysql.jsp?page=-"+Integer.toString(StartPage+1)+"">后10頁</a>");
out.print ("|");
%> </td>
</tr>
</table>
</body>
<%
//關(guān)閉結(jié)果集對(duì)象
sqlRst.close();
//關(guān)閉語句對(duì)象
sqlStmt.close ();
//關(guān)閉數(shù)據(jù)庫連接
sqlConn.close();
%> 程序結(jié)束
程序中的不足:
沒有對(duì)錯(cuò)誤進(jìn)行捕捉,但是這里只為了對(duì)jsp讀取Mysql數(shù)據(jù)庫進(jìn)行講解。如果是用與作留言本的話一定要對(duì)錯(cuò)誤進(jìn)行處理! 我們還要留言呢?
下面列出顯示留言的主要程序
<%@page import="java.sql.*"
import ="java.util.*"
import ="java.io.*"
contentType="text/html; charset=gb2312"
%>
<html>
<head>
<title>萍慧自由空間留言本</title>
<meta name="GENERATOR" content="Microsoft FrontPage 4.0">
<meta name="ProgId" content="FrontPage.Editor.Document">
<style type="text/css"><!--
body { font-size: 9pt}
td { font-size: 9pt}-->
</style>
</head>
<body>
<p align="center"><u><font size="5" face="華文新魏">萍慧自由空間留言本</font></u></p>
<table width="75%" border="1" bgcolor="#FFCCFF" bordercolorlight="#0000FF"
bordercolordark="#6666FF" cellpadding="0" cellspacing="0" align="center">
<tr>
<td colspan="5" height="202">
<%//下面處理用戶的分頁請(qǐng)求
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; //數(shù)據(jù)庫連接對(duì)象
java.sql.Statement sqlStmt; //語句對(duì)象
java.sql.ResultSet sqlRst; //結(jié)果集對(duì)象
//登記JDBC驅(qū)動(dòng)對(duì)象
Class.forName ("org.gjt.mm.mysql.Driver").newInstance ();
//連接數(shù)據(jù)庫
sqlConn= java.sql.DriverManager.getConnection ("jdbc:mysql://localhost/p","test","");
//創(chuàng)建語句對(duì)象
sqlStmt=sqlConn.createStatement
(java.sql.ResultSet.TYPE_SCROLL_INSENSITIVE,java.sql.ResultSet.CONCUR_READ_ONLY);
//執(zhí)行Sql語句
String sqlQuery="select count(*) from comment";
sqlRst=sqlStmt.executeQuery (sqlQuery);
sqlRst.next();
int count=sqlRst.getInt(1); //取得總的留言記錄數(shù)
if (Page>=0)RecoderPage=Page;//處理頁面
else RecoderPage=0-Page*10;
if (RecoderPage>count/15){ RecoderPage=count/15; Page=RecoderPage; }//頁面越界
RecoderRow=RecoderPage*15; //取得要顯示的留言記錄號(hào)
sqlQuery="select * from comment order by userid desc limit "+RecoderRow+",15;"; //一次讀取15條記錄
sqlRst=sqlStmt.executeQuery (sqlQuery);
%> 總共有<%=count%>條留言
<% while (sqlRst.next()) //顯示留言
{ //取得下一條記錄 %> 第<%=sqlRst.getString("userid")%>條
<table width="95%" border="1" cellspacing="1" cellpadding="1"
bordercolorlight="#6666FF" bordercolordark="#6666FF" bgcolor="#CCCCFF" align="center">
<tr>
<td width="25%">昵稱:<%=sqlRst.getString("username")%></td>
<td width="25%">性別:<%=sqlRst.getString("sex")%></td>
<td colspan="2" width="50%">地址:<%=sqlRst.getString("address") %></td>
</tr>
<tr>
<td width="25%">電話:<%=sqlRst.getString("telnumber")%></td>
<td width="25%">郵編:<%=sqlRst.getString("post")%></td>
<td width="25%">OICQ:<%=sqlRst.getString("oicq")%></td>
<td width="25%">ICQ:<%=sqlRst.getString("icq")%></td>
</tr>
<tr>
<td colspan="2" width="50%">Email:
<a href="mailto:<%=sqlRst.getString("email")%>" title="寫信給留言者"><%=sqlRst.getString("email")%></a></td>
<td colspan="2" width="50%">網(wǎng)址:
<a href target="_blank"></a><a href="mailto:<%=sqlRst.getString("url")%>" title="寫信給留言者">
<%=sqlRst.getString("urltitle")%></a></td>
</tr>
<tr>
<td colspan="4"><font style="line-height: 150%;color: green">
留言:<%=sqlRst.getString("comment")%><br>
-<%=sqlRst.getString("time") %>
(來自<%=sqlRst.getString("ip") %>)</font></td>
</tr>
</table>
<hr align="center" noshade size="2" width="95%">
<% } %> <%
//下面對(duì)留言進(jìn)行分頁
int i=count/15; //總頁,每頁顯示15條記錄
int j=i/10; //總的大頁 ,沒10個(gè)頁面分一大頁
//Page 顯示的頁面
int StartPage;
//int HrefPage;
if (Page<0) Page=0-Page*10; //10頁分一次
StartPage=Page/10; //10頁分一次
out.print ("[共有"+(i+1)+"頁]");
//out.print ("共有"+j+"屏");
//out.print ("顯示第"+Page+"頁");
//out.print ("StartPage="+StartPage);
if (StartPage>0)
out.print ("|<a href="connectmysql.jsp?page=-"+Integer.toString(StartPage-1)+"">前10頁</a>");
for (int k=0;k<10;k++)
{ int p=StartPage*10+k;
if (p>i) break;
if (p==Page)
out.print ("|第"+Integer.toString(p+1)+"頁");
else
out.print ("|<a href="connectmysql.jsp?page="+p+"">第"+Integer.toString(p+1)+"頁</a>");
}
if (StartPage<j)
out.print ("|<a href="connectmysql.jsp?page=-"+Integer.toString(StartPage+1)+"">后10頁</a>");
out.print ("|");
%> </td>
</tr>
</table>
</body>
<%
//關(guān)閉結(jié)果集對(duì)象
sqlRst.close();
//關(guān)閉語句對(duì)象
sqlStmt.close ();
//關(guān)閉數(shù)據(jù)庫連接
sqlConn.close();
%> 程序結(jié)束
程序中的不足:
沒有對(duì)錯(cuò)誤進(jìn)行捕捉,但是這里只為了對(duì)jsp讀取Mysql數(shù)據(jù)庫進(jìn)行講解。如果是用與作留言本的話一定要對(duì)錯(cuò)誤進(jìn)行處理! 我們還要留言呢?
相關(guān)文章
jsp+servlet實(shí)現(xiàn)猜數(shù)字游戲
這篇文章主要為大家詳細(xì)介紹了jsp+servlet實(shí)現(xiàn)猜數(shù)字游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-06-06
詳解JSP 內(nèi)置對(duì)象request常見用法
這篇文章主要介紹了詳解JSP 內(nèi)置對(duì)象request常見用法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-09-09
關(guān)于request.getHeader("Referer")的問題探討
request.getHeader("Referer")獲取上次訪問的URL鏈接,在什么情況下他會(huì)出現(xiàn)問題,下面為大家分享下,感興趣的朋友不要錯(cuò)過2013-10-10
Spring Annotaion Support詳細(xì)介紹及簡(jiǎn)單實(shí)例
這篇文章主要介紹了 Spring Annotaion Support詳細(xì)介紹及簡(jiǎn)單實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-03-03
基于jsp+servlet實(shí)現(xiàn)的簡(jiǎn)單博客系統(tǒng)實(shí)例(附源碼)
這篇文章主要介紹了基于jsp+servlet實(shí)現(xiàn)的簡(jiǎn)單博客系統(tǒng),以完整實(shí)例形式分析了基于jsp+servlet簡(jiǎn)單博客系統(tǒng)的原理與相關(guān)技巧,并附帶了完整源碼供讀者下載學(xué)習(xí),需要的朋友可以參考下2015-09-09

