JAVA教程之网上找到的JSP连接Oracle的原码
你总不能说你写框架吧,那无疑会加大工作量,现在大多企业采取的是折中的办法,就是改别人写好的框架,可要改框架,前提是你对这个框架足够的了解,这就更难了。js|oracleimportjava.io.Reader;
importjava.sql.*;
importjavax.servlet.ServletRequest;
importjavax.servlet.http.HttpServletRequest;
importoracle.jdbc.driver.OracleResultSet;
importoracle.sql.CLOB;
publicclassDb_sql
{
/**
*机关函数,newDb_sql的时分实行,挪用connect()毗连ORACLE数据库
*/
publicDb_sql(Strings,Strings1,Strings2,Strings3,Strings4)
throwsException
{
isClosed=false;
host=s.trim();
port=s1.trim();
sid=s2.trim();
user=s3.trim();
password=s4.trim();
connMgr=DBConnectionManager.getInstance();
connect();
}
/**
*毗连ORACLE数据库
*/
publicbooleanconnect()
throwsException
{
Strings="jdbc:oracle:thin:@"+host+":"+port+":"+sid;
conn=connMgr.getConnection(user,s,user,password);
returntrue;
}
/**
*是不是主动COMMIT
*/
publicvoidsetAutoCommit(booleanflag)
throwsSQLException
{
bAutoCommit=flag;
conn.setAutoCommit(flag);
}
/**
*没有设置成主动COMMIT,挪用该办法才会COMMIT
*/
publicvoidcommit()
throwsSQLException
{
if(!bAutoCommit)
conn.commit();
}
/**
*没有设置成主动COMMIT,挪用该办法才会ROLLBACK
*/
publicvoidrollback()
throwsSQLException
{
if(!bAutoCommit)
conn.rollback();
}
/**
*实行SQL,前往实行了局TRUE/FALSE
*/
publicResultSetquery(Strings)
throwsException
{
if(stmt==null)
stmt=conn.createStatement();
if(result!=null)
{
result.close();
result=null;
}
result=stmt.executeQuery(s);
returnresult;
}
publicvoidqueryLarge(Strings,Strings1)
throwsException
{
stmt.execute(s);
ResultSetresultset=stmt.getResultSet();
if(resultset.next())
{
CLOBclob=((OracleResultSet)resultset).getCLOB(1);
clob.putChars(1L,s1.toCharArray());
}
resultset.close();
}
/**
*把了局集里的指针下移一名
*/
publicbooleannext()
throwsSQLException
{
returnresult.next();
}
/**
*获得以后纪录的INT范例字段值,前后往空格
*/
publicintgetInt(Strings)
throwsSQLException
{
returnresult.getInt(s.trim());
}
/**
*获得以后纪录的STRING范例字段值,前后往空格
*/
publicStringgetString(Strings)
throwsSQLException
{
returnresult.getString(s.trim());
}
/**
*获得以后纪录的SHORT范例字段值,前后往空格
*/
publicshortgetShort(Strings)
throwsSQLException
{
returnresult.getShort(s.trim());
}
/**
*获得以后纪录的LONG范例字段值,前后往空格
*/
publiclonggetLong(Strings)
throwsSQLException
{
returnresult.getLong(s.trim());
}
/**
*获得以后纪录的DATE范例字段值,前后往空格
*/
publicDategetDate(Strings)
throwsSQLException
{
returnresult.getDate(s.trim());
}
/**
*获得以后纪录的TIME范例字段值,前后往空格
*/
publicTimegetTime(Strings)
throwsSQLException
{
returnresult.getTime(s.trim());
}
/**
*获得以后纪录的FLOAT范例字段值,前后往空格
*/
publicfloatgetFloat(Strings)
throwsSQLException
{
returnresult.getFloat(s.trim());
}
/**
*获得以后纪录的DOUBLE范例字段值,前后往空格
*/
publicdoublegetDouble(Strings)
throwsSQLException
{
returnresult.getDouble(s.trim());
}
/**
*获得以后纪录的BOOLEAN范例字段值,前后往空格
*/
publicbooleangetBoolean(Strings)
throwsSQLException
{
returnresult.getBoolean(s.trim());
}
/**
*获得以后纪录的CLOB范例字段值
*/
publicStringgetText(Strings)
throwsSQLException
{
Strings1="";
charac[]=newchar;
CLOBclob=(CLOB)result.getObject(s);
if(clob==null)
returnnull;
Readerreader=clob.getCharacterStream();
inti;
try
{
while((i=reader.read(ac,0,200))!=-1)
s1=s1+newString(ac,0,i);
}
catch(Exceptionexception1)
{
thrownewSQLException(exception1.getMessage());
}
finally
{
try
{
reader.close();
}
catch(Exception_ex){}
}
returns1;
}
/**
*封闭数据库毗连,实行COMMIT,RELEASE举措
*/
publicbooleanclose()
throwsSQLException
{
if(result!=null)
{
result.close();
result=null;
}
if(stmt!=null)
{
stmt.close();
stmt=null;
}
conn.setAutoCommit(true);
connMgr.freeConnection(user,conn);
connMgr.release(user);
isClosed=true;
returntrue;
}
/**
*没有挪用close()时,实行close()
*/
protectedvoidfinalize()
throwsSQLException
{
if(!isClosed)
close();
}
/**
*获得HTTP参数值,一切失掉的值都做了
*String(request.getParameter(s.trim()).trim().getBytes("ISO8859_1"),"GB2312")处置
*/
publicstaticStringgetParameter(HttpServletRequesthttpservletrequest,Strings)
{
try
{
if(httpservletrequest.getParameter(s.trim())!=null)
returnnewString(httpservletrequest.getParameter(s.trim()).trim().getBytes("ISO8859_1"),"GB2312");
else
returnnull;
}
catch(Exception_ex)
{
returnhttpservletrequest.getParameter(s.trim());
}
}
privateStringhost;
privateStringport;
privateStringdatabase;
privateStringuser;
privateStringpassword;
privateStringsid;
privatebooleanbAutoCommit;
publicResultSetresult;
publicStatementstmt;
publicintaffectedRows;
publicConnectionconn;
privatebooleanisClosed;
privateDBConnectionManagerconnMgr;
}
从一个编程语言的普及程度来将,一个好的IDE是至关中要的,而现在的java的IDE虽然已经很好了,但是和.net比起来还是稍微差一些的,这是个客观事实。java要想普及的更好。DE是必须加以改进的。 如果要向java web方向发展也要吧看看《Java web从入门到精通》学完再到《Struts2.0入门到精通》这样你差不多就把代码给学完了。有兴趣可以看一些设计模块和框架的包等等。 你就该学一学Servlet了。Servlet就是服务器端小程序,他负责生成发送给客户端的HTML文件。JSP在执行时,也是先转换成Servlet再运行的。虽说JSP理论上可以完全取代Servlet,这也是SUN推出JSP的本意,可是Servlet用来控制流程跳转还是挺方便的,也令程序更清晰。接下来你应该学习一下Javabean了,可能你早就看不管JSP在HTML中嵌Java代码的混乱方式了,这种方式跟ASP又有什么区别呢? 应用在电视机、电话、闹钟、烤面包机等家用电器的控制和通信。由于这些智能化家电的市场需求没有预期的高,Sun公司放弃了该项计划。随着1990年代互联网的发展 是一种简化的C++语言 是一种安全的语言,具有阻绝计算机病毒传输的功能 是一种将安全性(Security)列为第一优先考虑的语言 是一种为 Internet发展的计算机语言 一般学编程语言都是从C语开始学的,我也不例外,但还是可能不学过程语言而直接学面向对象语言的,你是刚接触语言,还是从C开始学比较好,基础会很深点,如果你直接学习JAVA也能上手,一般大家在学语言的时候都记一些语言的关键词,常有的包和接口等。再去做逻辑代码的编写,以后的学习过程都是从逻辑代码编写中提升的,所以这方面都是经验积累的。你要开始学习就从 Sun公司看见Oak在互联网上应用的前景,于是改造了Oak,于1995年5月以Java的名称正式发布。Java伴随着互联网的迅猛发展而发展,逐渐成为重要的网络编程语言。 如果你学过HTML,那么事情要好办的多,如果没有,那你快去补一补HTML基础吧。其实JSP中的Java语法也不多,它更象一个脚本语言,有点象ASP。 是一种将安全性(Security)列为第一优先考虑的语言 Java 编程语言的风格十分接近C、C++语言。 吧,现在很流行的Structs就是它的一种实现方式,不过Structs用起来实在是很繁,我们只要学习其精髓即可,我们完全可以设计自己的MVC结构。然后你再研究一下软件Refactoring (重构)和极限XP编程,相信你又会上一个台阶。 做完这些,你不如整理一下你的Java代码,把那些经典的程序和常见的应用整理出来,再精心打造一番,提高其重用性和可扩展性。你再找几个志同道合的朋友成立一个工作室吧 自从Sun推出Java以来,就力图使之无所不包,所以Java发展到现在,按应用来分主要分为三大块:J2SE,J2ME和J2EE,这也就是Sun ONE(Open Net Environment)体系。J2SE就是Java2的标准版,主要用于桌面应用软件的编程;J2ME主要应用于嵌入是系统开发,如手机和PDA的编程;J2EE是Java2的企业版,主要用于分布式的网络程序的开发,如电子商务网站和ERP系统。
页:
[1]