Pinghui Free Space Gästebuch
<%//Das Folgende behandelt die Paging-Anfrage des Benutzers 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) {Seite=0; } java.sql.Connection sqlConn; //Datenbankverbindungsobjekt java.sql.Statement sqlStmt; //Statement-Objekt java.sql.ResultSet sqlRst; //Ergebnissatzobjekt // JDBC-Treiberobjekt registrieren Class.forName ("org.gjt.mm.mysql.Driver").newInstance (); //Mit Datenbank verbinden sqlConn= java.sql.DriverManager.getConnection ("jdbc:mysql://localhost/p","test",""); //Anweisungsobjekt erstellen sqlStmt=sqlConn.createStatement (java.sql.ResultSet.TYPE_SCROLL_INSENSITIVE,java.sql.ResultSet.CONCUR_READ_ONLY); //SQL-Anweisung ausführen String sqlQuery="select count(*) from comment"; sqlRst=sqlStmt.executeQuery (sqlQuery); sqlRst.next(); int count=sqlRst.getInt(1); //Gesamtzahl der Nachrichtendatensätze abrufen if (Page>=0)RecoderPage=Page;//Seite verarbeiten sonst RecorderPage=0-Page*10; if (RecoderPage>count/15){ RecoderPage=count/15; Page=RecoderPage }//Die Seite ist außerhalb der Grenzen RecoderRow=RecoderPage*15; //Die anzuzeigende Nachrichtendatensatznummer abrufen sqlQuery="select * from comment order by userid desc limit "+RecoderRow+",15;" //15 Datensätze gleichzeitig lesen sqlRst=sqlStmt.executeQuery (sqlQuery); %> Es gibt insgesamt <%=count%> Nachrichten <% while (sqlRst.next()) //Nachrichten anzeigen { //Den nächsten Datensatz abrufen %> <%=sqlRst.getString("userid")%>
<% } %> <% //Page die Nachrichten unten int i=count/15; //Gesamtseite, jede Seite zeigt 15 Datensätze an int j=i/10; //Insgesamt große Seite, keine 10 Seiten werden in eine große Seite aufgeteilt //Seite zeigt Seite an int Startseite; //int HrefPage; if (Page<0) Page=0-Page*10; //10 Seiten einmal teilen StartPage=Page/10; // 10 Seiten gleichzeitig teilen out.print ("[Total "+(i+1)+"pages]"); //out.print ("total"+j+"screen"); //out.print ("Seite "+Seite+" anzeigen"); //out.print ("StartPage="+StartPage); if (StartPage>0) out.print ("|Erste 10 Seiten"); für (int k=0;k<10;k++) { int p=StartPage*10+k; if (p>i) break; if (p==Seite) out.print ("|th"+Integer.toString(p+1)+"page"); anders out.print ("|Page "+Integer.toString(p+1)+""); } if (StartPage out.print ("|"); %> |
%
//Schließen Sie das Ergebnismengenobjekt
sqlRst.close();
//Anweisungsobjekt schließen
sqlStmt.close();
//Datenbankverbindung schließen
sqlConn.close();
%> Mängel im Programmende:
Fehler werden nicht erfasst, dies dient jedoch lediglich dazu, das Lesen der MySQL-Datenbank durch JSP zu erläutern. Wenn Sie es als Gästebuch verwenden, müssen Sie mit den Fehlern umgehen! Möchten wir trotzdem eine Nachricht hinterlassen?