Cara menggunakan JSP+MySQL untuk membuat buku tamu (2)
Penulis:Eve Cole
Waktu Pembaruan:2009-07-02 17:13:19
Setelah Anda memiliki database, Anda perlu membaca pesan untuk pengoperasian database!
Program utama untuk menampilkan pesan tercantum di bawah ini:
<%@halaman import="java.sql.*"
import="java.util.*"
import="java.io.*"
contentType="teks/html; rangkaian karakter=gb2312"
%>
<html>
<kepala>
<title>Buku Tamu Ruang Bebas Pinghui</title>
<meta name="GENERATOR" content="Microsoft FrontPage 4.0">
<meta name="ProgId" content="FrontPage.Editor.Document">
<style type="teks/css"><!--
isi {ukuran font: 9pt}
td { ukuran font: 9pt}-->
</gaya>
</kepala>
<tubuh>
<p align="center"><u><font size="5" face="华文新伟">Buku Tamu Ruang Bebas Pinghui</font></u></p>
<lebar tabel="75%" border="1" bgcolor="#FFCCFF" bordercolorlight="#0000FF"
bordercolordark="#6666FF" cellpadding="0" Cellspacing="0" align="center">
<tr>
<td colspan="5" tinggi="202">
<%//Berikut ini menangani permintaan paging pengguna
String string_halaman;
int Halaman,Halaman Pengkode,Baris Pengkode;
coba{string_page=request.getParameter("halaman");
}tangkap (NullPointerException e){string_page="";}
coba{Page=Integer.parseInt(string_page);
}menangkap(NumberFormatException e)
{Halaman=0;
}
java.sql.Connection sqlConn; //Objek koneksi database
java.sql.Pernyataan sqlStmt; //Objek pernyataan
java.sql.ResultSet sqlRst; //Objek kumpulan hasil
//Daftarkan objek driver JDBC
Kelas.forName("org.gjt.mm.mysql.Driver").newInstance();
//Hubungkan ke basis data
sqlConn= java.sql.DriverManager.getConnection ("jdbc:mysql://localhost/p","test","");
//Buat objek pernyataan
sqlStmt=sqlConn.createStatement
(java.sql.ResultSet.TYPE_SCROLL_INSENSITIVE,java.sql.ResultSet.CONCUR_READ_ONLY);
//Jalankan pernyataan Sql
String sqlQuery="pilih hitungan(*) dari komentar";
sqlRst=sqlStmt.executeQuery (sqlQuery);
sqlRst.berikutnya();
int count=sqlRst.getInt(1); //Dapatkan jumlah total rekaman pesan
if (Halaman>=0)RecoderPage=Halaman;//halaman proses
else RecorderPage=0-Halaman*10;
if (RecoderPage>count/15){ RecoderPage=count/15; Page=RecoderPage }//Halaman di luar batas
RecoderRow=RecoderPage*15; //Dapatkan nomor rekaman pesan yang akan ditampilkan
sqlQuery="pilih * dari urutan komentar berdasarkan userid desc limit "+RecoderRow+",15; //Baca 15 catatan sekaligus
sqlRst=sqlStmt.executeQuery (sqlQuery);
%> Total ada <%=count%> pesan
<% while (sqlRst.next()) //Menampilkan pesan
{ //Dapatkan rekaman berikutnya %> <%=sqlRst.getString("userid")%>
<lebar tabel="95%" border="1" cellpacing="1" cellpadding="1"
bordercolorlight="#6666FF" bordercolordark="#6666FF" bgcolor="#CCCCFF" align="center">
<tr>
<td width="25%">Nama Panggilan: <%=sqlRst.getString("nama pengguna")%></td>
<td width="25%">Jenis Kelamin: <%=sqlRst.getString("sex")%></td>
<td colspan="2" width="50%">Alamat: <%=sqlRst.getString("address") %></td>
</tr>
<tr>
<td width="25%">Telepon: <%=sqlRst.getString("telnumber")%></td>
<td width="25%">Kode pos:<%=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="Tulis kepada orang yang meninggalkan pesan"><%=sqlRst.getString("email")%></a ></td>
<td colspan="2" width="50%">URL:
<a href target="_blank"></a><a href="mailto:<%=sqlRst.getString("url")%>" title="Tulis ke orang yang meninggalkan pesan">
<%=sqlRst.getString("urltitle")%></a></td>
</tr>
<tr>
<td colspan="4"><font style="tinggi garis: 150%;warna: hijau">
Pesan:<%=sqlRst.getString("komentar")%><br>
-<%=sqlRst.getString("waktu") %>
(dari <%=sqlRst.getString("ip") %>)</font></td>
</tr>
</tabel>
<hr align="center" noshade size="2" width="95%">
<% } %> <%
//Halaman pesan di bawah ini
int i=count/15; //Total halaman, setiap halaman menampilkan 15 record
int j=i/10; //Total halaman besar, tidak ada 10 halaman yang dibagi menjadi satu halaman besar
//Halaman ditampilkan halaman
int Halaman Awal;
//int HrefPage;
if (Halaman<0) Halaman=0-Halaman*10; //Bagi 10 halaman satu kali
StartPage=Halaman/10; //Bagi 10 halaman sekaligus
out.print("[Jumlah "+(i+1)+"halaman]");
//out.print("total"+j+"layar");
//out.print("Tampilan halaman "+Halaman+"");
//keluar.print("Halaman Awal="+Halaman Awal);
jika (Halaman Awal>0)
out.print ("|<a href="connectmysql.jsp?page=-"+Integer.toString(StartPage-1)+"">10 halaman pertama</a>");
untuk (int k=0;k<10;k++)
{ int p=Halaman Awal*10+k;
jika (p>i) putus;
jika (p==Halaman)
out.print("|th"+Integer.toString(p+1)+"halaman");
kalau tidak
out.print ("|<a href="connectmysql.jsp?page="+p+"">Halaman "+Integer.toString(p+1)+"</a>");
}
jika (Halaman Awal<j)
out.print ("|<a href="connectmysql.jsp?page=-"+Integer.toString(StartPage+1)+"">10 halaman berikutnya</a>");
keluar.cetak("|");
%> </td>
</tr>
</tabel>
</tubuh>
<%
//Tutup objek kumpulan hasil
sqlRst.close();
//Tutup objek pernyataan
sqlStmt.close();
//Tutup koneksi basis data
sqlConn.close();
%> Kekurangan pada program akhir program:
Kesalahan tidak ditangkap, tapi ini hanya untuk menjelaskan jsp membaca database Mysql. Jika Anda menggunakannya sebagai buku tamu, Anda harus mengatasi kesalahannya! Apakah kita masih ingin meninggalkan pesan?