JAVA网页设计JSP数据库操纵例程(Use Bean)
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;
pstr=temp_array;
nstr=temp_array;
lstr=temp_array;
}
/*
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;
inti=0;
intii=0;
while(i<=strLength-strInLength)
{
Stringtemp_str="";
for(intj=i;j<i+strInLength;j++)
{
temp_str=temp_str+temp_array;
}
if(temp_str.equals(strIn))
{
strInTimes++;
strIndex=i;
i=i+strInLength;
ii++;
}
else
{
i++;
}
}
if(strInTimes<1)
{
String[]back_str=null;
returnback_str;
}
else
{
Stringback_str[]=newString;
back_str=str.substring(0,strIndex);
for(intk=1;k<strInTimes;k++)
{
back_str=str.substring(strIndex+strInLength,strIndex);
}
back_str=str.substring(strIndex+strInLength,str.length());
returnback_str;
}
}
}
还得说上一点,就java本质而言,是面相对象的,但是你有没有发现,java也不全是,比如说基本类型,int,那他就是整型而不是对象,转换类型是还得借助包装类。 多重继承(以接口取代)等特性,增加了垃圾回收器功能用于回收不再被引用的对象所占据的内存空间,使得程序员不用再为内存管理而担忧。在 Java 1.5 版本中,Java 又引入了泛型编程(Generic Programming)、类型安全的枚举、不定长参数和自动装/拆箱等语言特性。 Java 不同于一般的编译执行计算机语言和解释执行计算机语言。它首先将源代码编译成二进制字节码(bytecode),然后依赖各种不同平台上的虚拟机来解释执行字节码。从而实现了“一次编译、到处执行”的跨平台特性。 所以现在应用最广泛又最好学的就是J2EE了。 J2EE又包括许多组件,如Jsp,Servlet,JavaBean,EJB,JDBC,JavaMail等。要学习起来可不是一两天的事。那么又该如何学习J2EE呢?当然Java语法得先看一看的,I/O包,Util包,Lang包你都熟悉了吗?然后再从JSP学起。 当然你也可以参加一些开源项目,一方面可以提高自己,另一方面也是为中国软件事业做贡献嘛!开发者在互联网上用CVS合作开发,用QQ,MSN,E-mail讨论联系,天南海北的程序员分散在各地却同时开发同一个软件,是不是很有意思呢? 不过,每次的执行编译后的字节码需要消耗一定的时间,这同时也在一定程度上降低了 Java 程序的运行效率。 在全球云计算和移动互联网的产业环境下,Java更具备了显著优势和广阔前景。 不过,每次的执行编译后的字节码需要消耗一定的时间,这同时也在一定程度上降低了 Java 程序的运行效率。 其实说这种话的人就如当年小日本号称“三个月拿下中国”一样大言不惭。不是Tomjava泼你冷水,你现在只是学到了Java的骨架,却还没有学到Java的精髓。接下来你得研究设计模式了。 任职于太阳微系统的詹姆斯·高斯林等人于1990年代初开发Java语言的雏形,最初被命名为Oak,目标设置在家用电器等小型系统的程序语言 http://www.jdon.com/去下载,或到同济技术论坛的服务器ftp://nro.shtdu.edu.cn去下,安装上有什么问题,可以到论坛上去提问。 Java 不同于一般的编译执行计算机语言和解释执行计算机语言。它首先将源代码编译成二进制字节码(bytecode),然后依赖各种不同平台上的虚拟机来解释执行字节码。从而实现了“一次编译、到处执行”的跨平台特性。 是一种为 Internet发展的计算机语言 当然你也可以参加一些开源项目,一方面可以提高自己,另一方面也是为中国软件事业做贡献嘛!开发者在互联网上用CVS合作开发,用QQ,MSN,E-mail讨论联系,天南海北的程序员分散在各地却同时开发同一个软件,是不是很有意思呢? 是一种简化的C++语言 是一种安全的语言,具有阻绝计算机病毒传输的功能 《JAVA语言程序设计》或《JAVA从入门到精通》这两本书开始学,等你编程有感觉的时候也可以回看一下。《JAVA读书笔记》这本书,因为讲的代码很多,也很容易看懂,涉及到面也到位。是你学习技术巩固的好书,学完后就看看《JAVA编程思想》这本书,找找一个自己写的代码跟书上的代码有什么不一样。 还好,SUN提供了Javabean可以把你的JSP中的 Java代码封装起来,便于调用也便于重用。 如果你学过HTML,那么事情要好办的多,如果没有,那你快去补一补HTML基础吧。其实JSP中的Java语法也不多,它更象一个脚本语言,有点象ASP。 任职于太阳微系统的詹姆斯·高斯林等人于1990年代初开发Java语言的雏形,最初被命名为Oak,目标设置在家用电器等小型系统的程序语言 你就该学一学Servlet了。Servlet就是服务器端小程序,他负责生成发送给客户端的HTML文件。JSP在执行时,也是先转换成Servlet再运行的。虽说JSP理论上可以完全取代Servlet,这也是SUN推出JSP的本意,可是Servlet用来控制流程跳转还是挺方便的,也令程序更清晰。接下来你应该学习一下Javabean了,可能你早就看不管JSP在HTML中嵌Java代码的混乱方式了,这种方式跟ASP又有什么区别呢?
页:
[1]