Rotina de operação de banco de dados JSP (Use Bean)
Autor:Eve Cole
Data da Última Atualização:2009-07-02 17:13:24
- Exibição de dados em páginas - JDBC 2.0: ODBC
Jsp pode operar o banco de dados através de jdbc:odbc. Neste exemplo, escrevi a conexão do banco de dados em um JavaBean, que pode ser reutilizado.
arquivo pagetest.jsp:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<%@page contentType="text/html;charset=gb2312" %>
<jsp:useBean id="Htool" scope="session" class="zbean.HtmlTool"/>
<jsp:useBean id="Jodb" scope="session" class="zbean.Jodb"/>
<html>
<cabeça>
<title>Teste de paginação do banco de dados</title>
</head>
<%
//Define a classe ResultSet
java.sql.ResultSet primeiro;
//Definir fonte de dados Odbc
Jodb.setConnStr("jdbc:odbc:jtest","","");
//Configura o driver Jdbc
Jodb.setDbDriver("sun.jdbc.odbc.JdbcOdbcDriver");
//Executa a instrução Sql e chama o método execute da classe Jodb
rst=Jodb.execute("selecione * do gbook");
%>
<%
int startRowNum;
int pageSize=10;
primeiro.último();
int rowCount=rst.getRow();
int pageCount=(rowCount+pageSize-1)/pageSize;
int intPágina;
String strPage=request.getParameter("página");
if(strPage==nulo)
{
intPágina=1;
}
outro
{
intPage=java.lang.Integer.parseInt(strPage);
if(intPage<1)intPage=1;
if(intPage>pageCount)intPage=pageCount;
}
startRowNum=(intPage-1)*pageSize+1;
%>
<corpo>
<div alinhar="centro">
<centro>
<p>Teste de paginação do banco de dados</p>
<p><%= Htool.getStr(Jodb.pageStr(intPage,pageCount,"pagetest.jsp?","en")) %></p>
<table border="1" width="600" bordercolorlight="#000000" cellpacing="0" cellpadding="2" bordercolordark="#FFFFFF">
<tr>
<td width="49"><font size="2">Número</font></td>
<td width="91"><font size="2">Nome</font></td>
<td width="174"><font size="2">E-mail</font></td>
<td width="250"><font size="2">Deixe uma mensagem</font></td>
</tr>
<%
for(int i=0;i<pageSize;i++){
primeiro.absoluto(startRowNum+i);
if(rst.isAfterLast())
{
quebrar;
}
%>
<tr>
<td width="49"><%= rst.getLong("id") %> </td>
<td width="91"><%= rst.getString("nome") %> </td>
<td width="174"><%= rst.getString("email") %> </td>
<td width="250"><%= rst.getString("pnote") %> <%= rst.getRow() %></td>
</tr>
<%
}
%>
</tabela>
</centro>
</div>
</body>
</html>
O arquivo Jodb.java é o seguinte:
pacote zbean;
importar java.sql.*;
//importar zbean.*;
classe pública Jodb
{
string pública sdbdriver="sun.jdbc.odbc.JdbcOdbcDriver";
string pública sConnStr;
contagem longa pública;
String uid;
Cadeia de caracteres pwd;
Conexão conn=nulo;
Conjunto de resultados rs=null;
publicJodb()
{
tentar
{
Class.forName(sdbdriver);
}
pegar(java.lang.ClassNotFoundException e)
{
System.err.println("Jodb():"+e.getMessage());
}
}
setDbDriver vazio público (String y)
{
sdbdriver=y;
}
public void setConnStr(String x,String z,String a)
{
sConnStr=x;
uid=z;
pwd=a;
}
executar ResultSet público (String sql)
{
rs=nulo;
tentar
{
conn=DriverManager.getConnection(sConnStr,uid,pwd);
Instrução stmt=conn.createStatement(java.sql.ResultSet.TYPE_SCROLL_SENSITIVE,java.sql.ResultSet.CONCUR_READ_ONLY);
rs=stmt.executeQuery(sql);
}
catch(SQLException ex)
{
System.err.println("Jodb.execute():"+ex.getMessage());
}
retornar rs;
}
atualização longa pública (String sql)
{
longo x=0;
tentar
{
conn=DriverManager.getConnection(sConnStr);
Instrução stmt=conn.createStatement();
x=stmt.executeUpdate(sql);
}
catch(SQLException ey)
{
System.err.println("Jodb.update():"+ey.getMessage());
}
retornar x;
}
string pública pageStr(int página,int pageCount,String url,String showStr)
{
//String str="Página:("+página+"/"+pageCount+") ";
Stringstr="";
String fstr;
String pstr;
String nstr;
String lstr;
//int página=currPage;
//int pageCount=pageCt;
if(showStr=="cn")
{
fstr="Primeira página";
pstr="página anterior";
nstr="próxima página";
lstr="última página";
}
senão if(showStr=="en")
{
fstr="Primeiro";
pstr="Anterior";
nstr="Próximo";
lstr="Último";
}
outro
{
String[] temp_array=split(showStr,"",");
if(temp_array==nulo)
{
str="Por favor, insira uma string como: "Primeiro,Anterior,Próximo,Último"";
retornar string;
}
fstr=temp_array[0];
pstr=temp_array[1];
nstr=temp_array[2];
lstr=temp_array[3];
}
/*
int npágina;
npgae=página+1;
int página;
ppage=página-1;
if(npage>pageCount)
{npae=contagem de páginas;}
se(ppgae<1)
{página=1;}
*/
if(página==1){
str=str+"<a href="+url+"page="+(page+1)+">"+nstr+"</a> ";
str=str+"<a href="+url+"page="+pageCount+">"+lstr+"</a> ";
}
if(página==contagem de páginas){
str=str+"<a href="+url+"page=1>"+fstr+"</a> ";
str=str+"<a href="+url+"page="+(page-1)+">"+pstr+"</a> ";
}
if(página>1&&página<pageCount){
str=str+"<a href="+url+"page=1>"+fstr+"</a> ";
str=str+"<a href="+url+"page="+(page-1)+">"+pstr+"</a> ";
str=str+"<a href="+url+"page="+(page+1)+">"+nstr+"</a> ";
str=str+"<a href="+url+"page="+pageCount+">"+lstr+"</a> ";
}
retornar string;
}
String pública [] divisão (String str,String strIn)
{
char[] temp_array;
temp_array=str.toCharArray();
int strComprimento=str.comprimento();
int strInLength=strIn.length();
int strInTimes=0;
int strIndex[]=new int[strComprimento];
int i=0;
intii=0;
enquanto(i<=strLength-strInLength)
{
String temp_str="";
for(int j=i;j<i+strInLength;j++)
{
temp_str=temp_str+temp_array[j];
}
if(temp_str.equals(strIn))
{
strInTimes++;
strIndex[ii]=i;
i=i+strInLength;
ii++;
}
outro
{
eu++;
}
}
if(strInTimes<1)
{
String[] back_str=null;
retornar back_str;
}
outro
{
String back_str[]=nova String[strInTimes+1];
back_str[0]=str.substring(0,strIndex[0]);
for(int k=1;k<strInTimes;k++)
{
back_str[k]=str.substring(strIndex[k-1]+strInLength,strIndex[k]);
}
back_str[strInTimes]=str.substring(strIndex[strInTimes-1]+strInLength,str.length());
retornar back_str;
}
}
}