|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
JAVA是一种可以撰写跨平台应用软件的面向对象的程序设计语言,由升阳(SunMicrosystems)公司的詹姆斯·高斯林(JamesGosling)等人于1990年代初开发。js|数据|数据库
-数据分页显现-JDBC2.0:ODBC
经由过程jdbc:odbc能够完成Jsp对数据库的操纵,在这个例子中我将数据库的毗连写在了一个JavaBean中,能够完成反复利用
pagetest.jsp文件:
<!DOCTYPEHTMLPUBLIC"-//W3C//DTDHTML4.0Transitional//EN">
<%@pagecontentType="text/html;charset=gb2312"%>
<jsp:useBeanid="Htool"scope="session"class="zbean.HtmlTool"/>
<jsp:useBeanid="Jodb"scope="session"class="zbean.Jodb"/>
<html>
<head>
<title>数据库分页测试</title>
</head>
<%
//界说ResultSet类
java.sql.ResultSetrst;
//设定Odbc数据源
Jodb.setConnStr("jdbc:odbc:jtest","","");
//设定Jdbc驱动程序
Jodb.setDbDriver("sun.jdbc.odbc.JdbcOdbcDriver");
//实行Sql语句,挪用Jodb类的execute办法
rst=Jodb.execute("select*fromgbook");
%>
<%
intstartRowNum;
intpageSize=10;
rst.last();
introwCount=rst.getRow();
intpageCount=(rowCount+pageSize-1)/pageSize;
intintPage;
StringstrPage=request.getParameter("page");
if(strPage==null)
{
intPage=1;
}
else
{
intPage=java.lang.Integer.parseInt(strPage);
if(intPage<1)intPage=1;
if(intPage>pageCount)intPage=pageCount;
}
startRowNum=(intPage-1)*pageSize+1;
%>
<body>
<divalign="center">
<center>
<p>数据库分页测试</p>
<p><%=Htool.getStr(Jodb.pageStr(intPage,pageCount,"pagetest.jsp?","en"))%></p>
<tableborder="1"width="600"bordercolorlight="#000000"cellspacing="0"cellpadding="2"bordercolordark="#FFFFFF">
<tr>
<tdwidth="49"><fontsize="2">编号</font></td>
<tdwidth="91"><fontsize="2">姓名</font></td>
<tdwidth="174"><fontsize="2">电子邮箱</font></td>
<tdwidth="250"><fontsize="2">留言</font></td>
</tr>
<%
for(inti=0;i<pageSize;i++){
rst.absolute(startRowNum+i);
if(rst.isAfterLast())
{
break;
}
%>
<tr>
<tdwidth="49"><%=rst.getLong("id")%> </td>
<tdwidth="91"><%=rst.getString("name")%> </td>
<tdwidth="174"><%=rst.getString("email")%> </td>
<tdwidth="250"><%=rst.getString("pnote")%> <%=rst.getRow()%></td>
</tr>
<%
}
%>
</table>
</center>
</div>
</body>
</html>
Jodb.java文件以下:
packagezbean;
importjava.sql.*;
//importzbean.*;
publicclassJodb
{
publicStringsdbdriver="sun.jdbc.odbc.JdbcOdbcDriver";
publicStringsConnStr;
publiclongcount;
Stringuid;
Stringpwd;
Connectionconn=null;
ResultSetrs=null;
publicJodb()
{
try
{
Class.forName(sdbdriver);
}
catch(java.lang.ClassNotFoundExceptione)
{
System.err.println("Jodb():"+e.getMessage());
}
}
publicvoidsetDbDriver(Stringy)
{
sdbdriver=y;
}
publicvoidsetConnStr(Stringx,Stringz,Stringa)
{
sConnStr=x;
uid=z;
pwd=a;
}
publicResultSetexecute(Stringsql)
{
rs=null;
try
{
conn=DriverManager.getConnection(sConnStr,uid,pwd);
Statementstmt=conn.createStatement(java.sql.ResultSet.TYPE_SCROLL_SENSITIVE,java.sql.ResultSet.CONCUR_READ_ONLY);
rs=stmt.executeQuery(sql);
}
catch(SQLExceptionex)
{
System.err.println("Jodb.execute():"+ex.getMessage());
}
returnrs;
}
publiclongupdate(Stringsql)
{
longx=0;
try
{
conn=DriverManager.getConnection(sConnStr);
Statementstmt=conn.createStatement();
x=stmt.executeUpdate(sql);
}
catch(SQLExceptioney)
{
System.err.println("Jodb.update():"+ey.getMessage());
}
returnx;
}
publicStringpageStr(intpage,intpageCount,Stringurl,StringshowStr)
{
//Stringstr="Page:("+page+"/"+pageCount+")";
Stringstr="";
Stringfstr;
Stringpstr;
Stringnstr;
Stringlstr;
//intpage=currPage;
//intpageCount=pageCt;
if(showStr=="cn")
{
fstr="第一页";
pstr="上一页";
nstr="下一页";
lstr="最末页";
}
elseif(showStr=="en")
{
fstr="First";
pstr="Previous";
nstr="Next";
lstr="Last";
}
else
{
String[]temp_array=split(showStr,",");
if(temp_array==null)
{
str="PleaseinputStringlike:"First,Previous,Next,Last"";
returnstr;
}
fstr=temp_array[0];
pstr=temp_array[1];
nstr=temp_array[2];
lstr=temp_array[3];
}
/*
intnpage;
npgae=page+1;
intppage;
ppage=page-1;
if(npage>pageCount)
{npae=pageCount;}
if(ppgae<1)
{ppage=1;}
*/
if(page==1){
str=str+"<ahref="+url+"page="+(page+1)+">"+nstr+"</a>";
str=str+"<ahref="+url+"page="+pageCount+">"+lstr+"</a>";
}
if(page==pageCount){
str=str+"<ahref="+url+"page=1>"+fstr+"</a>";
str=str+"<ahref="+url+"page="+(page-1)+">"+pstr+"</a>";
}
if(page>1&&page<pageCount){
str=str+"<ahref="+url+"page=1>"+fstr+"</a>";
str=str+"<ahref="+url+"page="+(page-1)+">"+pstr+"</a>";
str=str+"<ahref="+url+"page="+(page+1)+">"+nstr+"</a>";
str=str+"<ahref="+url+"page="+pageCount+">"+lstr+"</a>";
}
returnstr;
}
publicString[]split(Stringstr,StringstrIn)
{
char[]temp_array;
temp_array=str.toCharArray();
intstrLength=str.length();
intstrInLength=strIn.length();
intstrInTimes=0;
intstrIndex[]=newint[strLength];
inti=0;
intii=0;
while(i<=strLength-strInLength)
{
Stringtemp_str="";
for(intj=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++;
}
else
{
i++;
}
}
if(strInTimes<1)
{
String[]back_str=null;
returnback_str;
}
else
{
Stringback_str[]=newString[strInTimes+1];
back_str[0]=str.substring(0,strIndex[0]);
for(intk=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());
returnback_str;
}
}
}
还得说上一点,就java本质而言,是面相对象的,但是你有没有发现,java也不全是,比如说基本类型,int,那他就是整型而不是对象,转换类型是还得借助包装类。 |
|