下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
如何实现jdbc性能优化
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(“/forum/images/smiles/icon_surprised.gifborder=0>racle:thin:@hostsString”,props);
对象可以通过设置setDefaultRowPrefetch(int)和setDefaultBatchValue(int)两个参数类优化连接
2.使用连接池可以自己写一个连接池这样程序的敏捷性强,便于移植.
apache项目开发了一套特别通用而表现特别稳定的对象池/mons/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.mit();
connection.setAutoCommit(true);
}
catch(SQLExceptione){
}
finally{
//代码
if(connection!=null){
connection.close();
}
}
4.适当的选择事务的隔离级别TRANSACTION_READ_UNMITED性能最高
TRANSACTION_READ_MITED快
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
单向滚动性能比较高.
其他方面的性能优化
准
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 免疫化疗患者的感染防控
- 万达工程造价审计制度
- 中心中医绩效考核制度
- 保安队绩效考核制度
- 出版策划绩效考核制度
- 农民夜校教育培训制度
- 仲裁员教育培训制度
- 审计局公务接待管理制度
- 审计项目责任追究制度
- 三亚绩效考核制度
- 2026年内蒙古自治区招收事业编制行政执法人员1991人参考笔试试题及答案解析
- 质量环境及职业健康安全三体系风险和机遇识别评价分析及控制措施表(包含气候变化)
- 农业种植基地合作开发和利益分配协议
- 湖北2025年地生中考试卷及答案
- 2025年高职汽车检测与维修技术(汽车检测)试题及答案
- 2025年11月近期典型事故案例警示教育
- 卵巢肿瘤病例讨论课件
- 2025年时事热点政治题及参考答案(满分必刷)
- 2026年国网内蒙古东部电力校园招聘(工程管理类)复习题及答案
- 2025年大学《老年学-老年学概论》考试备考试题及答案解析
- 2025年江苏安全技术职业学院单招职业技能测试题库完整答案详解
评论
0/150
提交评论