仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 1027|回复: 18
打印 上一主题 下一主题

[学习教程] JAVA网页设计JDBC进修条记-jdbc功能优化

[复制链接]
谁可相欹 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-18 11:39:27 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
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性能上肯定会站上风的。
兰色精灵 该用户已被删除
沙发
发表于 2015-1-18 21:10:44 | 只看该作者
你就该学一学Servlet了。Servlet就是服务器端小程序,他负责生成发送给客户端的HTML文件。JSP在执行时,也是先转换成Servlet再运行的。虽说JSP理论上可以完全取代Servlet,这也是SUN推出JSP的本意,可是Servlet用来控制流程跳转还是挺方便的,也令程序更清晰。接下来你应该学习一下Javabean了,可能你早就看不管JSP在HTML中嵌Java代码的混乱方式了,这种方式跟ASP又有什么区别呢?
不帅 该用户已被删除
板凳
发表于 2015-1-23 17:39:30 | 只看该作者
有时间再研究一下MVC结构(把Model-View-Control分离开的设计思想)
飘飘悠悠 该用户已被删除
地板
发表于 2015-1-28 12:55:27 | 只看该作者
是一种为 Internet发展的计算机语言
admin 该用户已被删除
5#
发表于 2015-2-1 06:20:20 | 只看该作者
你现在最缺的是实际的工作经验,而不是书本上那些凭空想出来的程序。
小女巫 该用户已被删除
6#
发表于 2015-2-1 19:51:39 | 只看该作者
自从Sun推出Java以来,就力图使之无所不包,所以Java发展到现在,按应用来分主要分为三大块:J2SE,J2ME和J2EE,这也就是Sun ONE(Open Net Environment)体系。J2SE就是Java2的标准版,主要用于桌面应用软件的编程;J2ME主要应用于嵌入是系统开发,如手机和PDA的编程;J2EE是Java2的企业版,主要用于分布式的网络程序的开发,如电子商务网站和ERP系统。
再见西城 该用户已被删除
7#
发表于 2015-2-10 04:24:34 | 只看该作者
当然你也可以参加一些开源项目,一方面可以提高自己,另一方面也是为中国软件事业做贡献嘛!开发者在互联网上用CVS合作开发,用QQ,MSN,E-mail讨论联系,天南海北的程序员分散在各地却同时开发同一个软件,是不是很有意思呢?
第二个灵魂 该用户已被删除
8#
发表于 2015-2-11 20:25:51 | 只看该作者
你现在最缺的是实际的工作经验,而不是书本上那些凭空想出来的程序。
9#
发表于 2015-2-12 23:48:24 | 只看该作者
应用在电视机、电话、闹钟、烤面包机等家用电器的控制和通信。由于这些智能化家电的市场需求没有预期的高,Sun公司放弃了该项计划。随着1990年代互联网的发展
深爱那片海 该用户已被删除
10#
发表于 2015-3-3 11:17:35 | 只看该作者
Java 编程语言的风格十分接近C、C++语言。
谁可相欹 该用户已被删除
11#
 楼主| 发表于 2015-3-11 10:16:28 | 只看该作者
不过,每次的执行编译后的字节码需要消耗一定的时间,这同时也在一定程度上降低了 Java 程序的运行效率。
灵魂腐蚀 该用户已被删除
12#
发表于 2015-3-21 17:00:15 | 只看该作者
是一种语言,用以产生「小应用程序(Applet(s))
飘灵儿 该用户已被删除
13#
发表于 2015-4-1 09:37:59 | 只看该作者
Java自面世后就非常流行,发展迅速,对C++语言形成了有力冲击。Java 技术具有卓越的通用性、高效性、平台移植性和安全性,广泛应用于个人PC、数据中心、游戏控制台
再现理想 该用户已被删除
14#
发表于 2015-4-15 11:19:41 | 只看该作者
吧,现在很流行的Structs就是它的一种实现方式,不过Structs用起来实在是很繁,我们只要学习其精髓即可,我们完全可以设计自己的MVC结构。然后你再研究一下软件Refactoring (重构)和极限XP编程,相信你又会上一个台阶。 做完这些,你不如整理一下你的Java代码,把那些经典的程序和常见的应用整理出来,再精心打造一番,提高其重用性和可扩展性。你再找几个志同道合的朋友成立一个工作室吧
分手快乐 该用户已被删除
15#
发表于 2015-4-19 10:44:19 | 只看该作者
你一定会高兴地说,哈哈,原来成为Java高手就这么简单啊!记得Tomjava也曾碰到过一个项目经理,号称Java很简单,只要三个月就可以学会。
蒙在股里 该用户已被删除
16#
发表于 2015-4-23 22:14:26 | 只看该作者
是一种突破用户端机器环境和CPU
简单生活 该用户已被删除
17#
发表于 2015-4-24 20:26:56 | 只看该作者
Jive的资料在很多网站上都有,大家可以找来研究一下。相信你读完代码后,会有脱胎换骨的感觉。遗憾的是Jive从2.5以后就不再无条件的开放源代码,同时有licence限制。不过幸好还有中国一流的Java程序员关注它,外国人不开源了,中国人就不能开源吗?这里向大家推荐一个汉化的Jive版本—J道。Jive(J道版)是由中国Java界大名 鼎鼎的banq在Jive 2.1版本基础上改编而成, 全中文,增加了一些实用功能,如贴图,用户头像和用户资料查询等,而且有一个开发团队在不断升级。你可以访问banq的网站
老尸 该用户已被删除
18#
发表于 2015-5-2 06:59:28 | 只看该作者
Java语言支持Internet应用的开发,在基本的Java应用编程接口中有一个网络应用编程接口(java net),它提供了用于网络应用编程的类库,包括URL、URLConnection、Socket、ServerSocket等。Java的RMI(远程方法激活)机制也是开发分布式应用的重要手段。
海妖 该用户已被删除
19#
发表于 2015-5-5 03:38:07 | 只看该作者
至于JDBC,就不用我多说了,你如果用java编过存取数据库的程序,就应该很熟悉。还有,如果你要用Java编发送电子邮件的程序,你就得看看Javamail 了。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-5-26 00:56

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表