JSP+MySQLを使ってゲストブックを作成する方法(2)
著者:Eve Cole
更新時間:2009-07-02 17:13:19
データベースを取得したら、データベース操作のメッセージを読む必要があります。
メッセージを表示する主なプログラムは次のとおりです。
<%@page import="java.sql.*"
import="java.util.*"
import="java.io.*"
contentType="テキスト/html; charset=gb2312"
%>
<html>
<頭>
<title>平恵フリー スペース ゲストブック</title>
<meta name="GENERATOR" content="Microsoft FrontPage 4.0">
<meta name="ProgId" content="FrontPage.Editor.Document">
<style type="text/css"><!--
本文 {font-size: 9pt}
td {フォントサイズ: 9pt}-->
</スタイル>
</head>
<本文>
<p align="center"><u><font size="5" face="华文新伟">平恵フリー スペース ゲストブック</font></u></p>
<table width="75%" border="1" bgcolor="#FFCCFF" bordercolorlight="#0000FF"
bordercolordark="#6666FF" cellpadding="0" cellpacing="0" align="center">
<tr>
<tdcolspan="5" height="202">
<%//以下はユーザーのページングリクエストを処理します
文字列 string_page;
int ページ、RecoderPage、RecoderRow;
try{string_page=request.getParameter("ページ");
}catch (NullPointerException e){string_page="";}
try{Page=Integer.parseInt(string_page);
}catch(NumberFormatException e)
{ページ=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="コメントからカウント(*)を選択";
sqlRst=sqlStmt.executeQuery (sqlQuery);
sqlRst.next();
int count=sqlRst.getInt(1); //メッセージレコードの総数を取得します。
if (Page>=0)RecoderPage=Page;//ページを処理します
else RecorderPage=0-ページ*10;
if (RecoderPage>count/15){ RecoderPage=count/15 }//ページは範囲外です。
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")%>
<table width="95%" border="1" cellpacing="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%">メール:
<a href="mailto:<%=sqlRst.getString("email")%>" title="メッセージを残した人に書き込む"><%=sqlRst.getString("email")%></a ></td>
<tdcolspan="2" width="50%">URL:
<a href target="_blank"></a><a href="mailto:<%=sqlRst.getString("url")%>" title="メッセージを残した人に書き込む">
<%=sqlRst.getString("urltitle")%></a></td>
</tr>
<tr>
<tdcolspan="4"><font style="line-height: 150%;color: green">
メッセージ:<%=sqlRst.getString("comment")%><br>
-<%=sqlRst.getString("time") %>
(<%=sqlRst.getString("ip") %> から)</font></td>
</tr>
</テーブル>
<hr align="center" noshade size="2" width="95%">
<% } %> <%
// 以下のメッセージをページングします
int i=count/15; //合計ページ、各ページに 15 件のレコードが表示されます。
int j=i/10; //ラージ ページ全体、10 ページは 1 つのラージ ページに分割されません
//ページ表示ページ
int StartPage;
//int HrefPage;
if (Page<0) Page=0-Page*10; //10ページを1回分割
StartPage=Page/10; //一度に10ページずつ分割します
out.print ("[合計 "+(i+1)+" ページ数]");
//out.print ("合計"+j+"画面");
//out.print ("ページを表示 "+Page+"");
//out.print ("StartPage="+StartPage);
if (開始ページ>0)
out.print ("|<a href="connectmysql.jsp?page=-"+Integer.toString(StartPage-1)+"">最初の 10 ページ</a>");
for (int k=0;k<10;k++)
{ int p=開始ページ*10+k;
if (p>i) ブレーク;
if (p==ページ)
out.print ("| 番目"+Integer.toString(p+1)+"ページ");
それ以外
out.print ("|<a href="connectmysql.jsp?page="+p+"">ページ "+Integer.toString(p+1)+"</a>");
}
if (開始ページ<j)
out.print ("|<a href="connectmysql.jsp?page=-"+Integer.toString(StartPage+1)+"">次の 10 ページ</a>");
out.print ("|");
%> </td>
</tr>
</テーブル>
</body>
<%
//結果セットオブジェクトを閉じる
sqlRst.close();
//ステートメントオブジェクトを閉じる
sqlStmt.close();
//データベース接続を閉じる
sqlConn.close();
%> プログラム終了プログラムの不備:
エラーはキャプチャされませんが、これは JSP が MySQL データベースを読み取ることを説明するためのものです。ゲストブックとして使用している場合は、エラーに対処する必要があります。 まだメッセージを残したいですか?