JAVA网页设计JDBC进修条记-jdbc功能优化
java也能做一些底层语言开发做的事情(难度很高,不是java顶尖高手是做不来的),条记|功能|优化jdbc程序的功能次要由两个要素决意,一是数据库自己的性子,另外一个是与数据库绝对自力的jdbc使用程序接口(api)的利用.这里说的是怎样准确利用jdbc编程接口,以取得更好的功能.jdbc次要优化有:
1.选择准确的jdbc驱动程序
2.Connention的优化利用毗连池来办理Connection对象
3.Statement的优化利用批量更新等
4.Result的优化准确的从数据库中get数据等
(1)选择准确的jdbc驱动程序:
1jdbc-odbc桥
2当地api-部分java驱动
3jdbc网路协定-纯java驱动
4jdbc当地协定
最好选择jdbc网路协定-纯java驱动效力对照高但必要第三方软件的撑持好比corbaweblogic属于这类范例
(2)优化Connection对象:
1.设置得当的参数DriverManager.getConnection(Stringurl,Propertiesprops);
比方:Propertiesprops=newProperties();
props.put("user","wuwei");
props.put("password","wuwei");
props.put("defaultRowPrefectch","30");
props.put("dufaultBatchValue","5");
Connectioncon=DriverManager.getConnection("jdbc:oracle:thin:@hostsString",props);
对象能够经由过程设置setDefaultRowPrefetch(int)和setDefaultBatchValue(int)两个参数类优化毗连
2.利用毗连池能够本人写一个毗连池如许程序的天真性强,便于移植.
apache项目开辟了一套十分通用而体现十分不乱的对象池http://jakarta.apache.org/commons/pool.htm
计划了本人的毗连池后在客户端挪用创建对象
publicObjectmakeObject()throwsException{
Class.forName("oracle.jdbc.driver.OracalDriver");
returnDriverManager.getConnection("url","username","password");
}
烧毁对象时用
publicvoiddestroyObject(Objectobj)throwsException{
((Connection)obj.close());
}
注重几点对象池里有无接纳机制,对象池里无机有容量限定,对象池里有几个闲置对象(能够开释)
3.把持事件的提交最妙手动提交事件,不仅能够能够包管数据原子性,并且对新能进步留下余地.
try{
connection.setAutoCommint(false);
//代码用PreparedStatement功能比Statementh好.
connection.commit();
connection.setAutoCommit(true);
}
catch(SQLExceptione){
}
finally{
//代码
if(connection!=null){
connection.close();
}
}
4.得当的选择事件的断绝级别TRANSACTION_READ_UNCOMMITED功能最高
TRANSACTION_READ_COMMITED快
TRANSACTION_REFEATABLE_READ中等
RANSACTION_SERIALIZABLE慢
(3)Statement优化
jdbc3个接口用来处置sql的实行,是StatementPreparedStatementCallableStatement
供应得当的Statement接口
批量实行sql
从数据库批量猎取数据
PreparedStatement比Statement功能要好次要表现在一个sql语句屡次反复实行的情形
PreparedStatemnt只编译剖析一次而Statement每次编译一次.
批量修正数据库
Statement供应了办法addBatch(String)和executeBatch()
挪用办法为stmt.addBatch("isnert.....");stmt.addBatch("update.....")
stmt.executeBatch();
也能够用PreparedStatement从而更好的进步功能.
pstmt=conn.preparedStatement("insertintotest_table(......)values(....?)");
pstmt.setString(1,"aaa");
pstmt.addBatch();
pstmt.setString(1,"bbb");
pstmt.addBatch();
.....
pstmt.executeBatch();
批量地从数据库中取数据.
经由过程setFetchSize()和getFectchSize()办法来设定和检察这个参数.这个参数对体统的功能影响对照年夜.
这个参数太小会严峻地下降程序地功能.
ConnectionStatementResultSet都有这个参数,他们对功能地影响按次是:
ResultSet---------Statement---------Connection
(4)优化ResultSet.
表现在以下几个方面
批量读取数据.公道设置ResultSet的getFetchSize()和setFetchSize()办法中的参数
利用准确的get和set办法
利用整数而不是字段名作为参数功能对照高,
比方setInt(1,100);
setString(2,"aaaa");
比setInt("id","100");
setString("name","aaaa");
功能好
设置得当的转动偏向.有3个偏向FETCH_FORWORD,FETCH_REVERSEFETCH_UNKNOWN
单向转动功能对照高.
其他方面的功能优化
实时显现的封闭ConnectionStatementResultSet
个中Connection能够用ConnetionPool处置.
利用数据库体系的壮大查询功效往构造数据.如许程序运转是和数据库服务的交互次数少,数据库前往给
程序的纪录条数少的多,以是功能有很年夜的进步.
你说是sun公司对她研究的透还是微软?针对自己工具开发的.net性能上肯定会站上风的。 你就该学一学Servlet了。Servlet就是服务器端小程序,他负责生成发送给客户端的HTML文件。JSP在执行时,也是先转换成Servlet再运行的。虽说JSP理论上可以完全取代Servlet,这也是SUN推出JSP的本意,可是Servlet用来控制流程跳转还是挺方便的,也令程序更清晰。接下来你应该学习一下Javabean了,可能你早就看不管JSP在HTML中嵌Java代码的混乱方式了,这种方式跟ASP又有什么区别呢? 有时间再研究一下MVC结构(把Model-View-Control分离开的设计思想) 是一种为 Internet发展的计算机语言 你现在最缺的是实际的工作经验,而不是书本上那些凭空想出来的程序。 自从Sun推出Java以来,就力图使之无所不包,所以Java发展到现在,按应用来分主要分为三大块:J2SE,J2ME和J2EE,这也就是Sun ONE(Open Net Environment)体系。J2SE就是Java2的标准版,主要用于桌面应用软件的编程;J2ME主要应用于嵌入是系统开发,如手机和PDA的编程;J2EE是Java2的企业版,主要用于分布式的网络程序的开发,如电子商务网站和ERP系统。 当然你也可以参加一些开源项目,一方面可以提高自己,另一方面也是为中国软件事业做贡献嘛!开发者在互联网上用CVS合作开发,用QQ,MSN,E-mail讨论联系,天南海北的程序员分散在各地却同时开发同一个软件,是不是很有意思呢? 你现在最缺的是实际的工作经验,而不是书本上那些凭空想出来的程序。 应用在电视机、电话、闹钟、烤面包机等家用电器的控制和通信。由于这些智能化家电的市场需求没有预期的高,Sun公司放弃了该项计划。随着1990年代互联网的发展 Java 编程语言的风格十分接近C、C++语言。 不过,每次的执行编译后的字节码需要消耗一定的时间,这同时也在一定程度上降低了 Java 程序的运行效率。 是一种语言,用以产生「小应用程序(Applet(s)) Java自面世后就非常流行,发展迅速,对C++语言形成了有力冲击。Java 技术具有卓越的通用性、高效性、平台移植性和安全性,广泛应用于个人PC、数据中心、游戏控制台 吧,现在很流行的Structs就是它的一种实现方式,不过Structs用起来实在是很繁,我们只要学习其精髓即可,我们完全可以设计自己的MVC结构。然后你再研究一下软件Refactoring (重构)和极限XP编程,相信你又会上一个台阶。 做完这些,你不如整理一下你的Java代码,把那些经典的程序和常见的应用整理出来,再精心打造一番,提高其重用性和可扩展性。你再找几个志同道合的朋友成立一个工作室吧 你一定会高兴地说,哈哈,原来成为Java高手就这么简单啊!记得Tomjava也曾碰到过一个项目经理,号称Java很简单,只要三个月就可以学会。 是一种突破用户端机器环境和CPU Jive的资料在很多网站上都有,大家可以找来研究一下。相信你读完代码后,会有脱胎换骨的感觉。遗憾的是Jive从2.5以后就不再无条件的开放源代码,同时有licence限制。不过幸好还有中国一流的Java程序员关注它,外国人不开源了,中国人就不能开源吗?这里向大家推荐一个汉化的Jive版本—J道。Jive(J道版)是由中国Java界大名 鼎鼎的banq在Jive 2.1版本基础上改编而成, 全中文,增加了一些实用功能,如贴图,用户头像和用户资料查询等,而且有一个开发团队在不断升级。你可以访问banq的网站 Java语言支持Internet应用的开发,在基本的Java应用编程接口中有一个网络应用编程接口(java net),它提供了用于网络应用编程的类库,包括URL、URLConnection、Socket、ServerSocket等。Java的RMI(远程方法激活)机制也是开发分布式应用的重要手段。 至于JDBC,就不用我多说了,你如果用java编过存取数据库的程序,就应该很熟悉。还有,如果你要用Java编发送电子邮件的程序,你就得看看Javamail 了。
页:
[1]