关于CallableStatement执行效率问题

liguiqing 2006-04-29 11:00:19
在Oracle(9.0.1)先将要处理的数据(1000条以上)插入临时表,然后再调用一存储过程对这批数据进行集中处理,并返回处理信息,此存储过程在PL/SQL环境相同数据量下测试执行时间为10秒左右,但是通过CallableStatement去执行需要130秒左右(即调用executeQuery()后消耗的时间),经过测试,存储过程执行完成的时间也在10秒左右,但是在执行完返回的过程中消耗上百秒,如果去除返回值,也还需要50秒左右,百思不得其解,不知是否与驱动程序有关?(驱动为oracle的classes12.zip)
...全文
325 7 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
Jerry_Gao 2006-12-16
  • 打赏
  • 举报
回复
帮顶一下.我也面临同样的问题啊。
一个查询,用SQL PLUS执行大约1S(在清空过BUFFER CACHE 和 SHARED POOL的情况下).
用PreparedStatement执行就10S.
效率降低大约10倍.

希望高手来帮忙啊。
wd_6532 2006-11-18
  • 打赏
  • 举报
回复
mark
liguiqing 2006-04-30
  • 打赏
  • 举报
回复
游标的效率低?何解?为什么同样的数据量在PL/SQL下测试,执行效率就高了10多信
liguiqing 2006-04-30
  • 打赏
  • 举报
回复
完整的程序:
public List executeCallable(final String plsqlName, final Object[] params) {
return (List) new DataAccssesExecuteTemplet().run(new ITemplet() {
public Object execute() throws SQLException {
List results = null;
String plsql = getPLSQL(plsqlName, params);
LogHelper.logger.info("executeStatement: " + plsql);
Connection cn = null;
CallableStatement cs = null;
try {
cn = getConnection();
cs = cn.prepareCall(plsql);
setParamToStatement(cs, params,true);

cs.execute();//1000条数据,就这个调用需要130S,在PL/SQL下测试相同数据量,只要10S
results = parseStatement(cs, params);
} finally {
closeCallable(cs, cn);
}
return results;

}

private String getPLSQL(String plsqlName, Object[] params) {
StringBuffer parameters = new StringBuffer();
boolean hashReturnValue = true;
if((params[0]+"").startsWith("OracleTypes")){
parameters.append("{ ? = call " + plsqlName + "(");

}else{
parameters.append("{ call " + plsqlName + "(");
hashReturnValue = false;
}
for (int i = 0; i < params.length; i++) {
parameters.append("?,");
}
if(parameters.length()>3 && hashReturnValue)
parameters.delete(parameters.length()-3,parameters.length());
else
parameters.delete(parameters.length()-1,parameters.length());
parameters.append(") }");
return parameters.toString();
}

// 执行SQL语句并返回一个List封装的多个返回参数集
private List parseStatement(CallableStatement cs, Object[] params)throws SQLException {
ArrayList list = new ArrayList();
for (int i = 0; i < params.length; i++) {
String value = params[i] + "";
if (value.startsWith("OracleTypes")) {
if ("OracleTypes.CURSOR".equals(value)) {
ResultSet rs = (ResultSet) cs.getObject(i + 1);
list.add(covered(rs));
closeAll(rs, null, null);
} else {
list.add(cs.getObject(i + 1));
}
}
}
return list;
}
});
}
kingofworl 2006-04-30
  • 打赏
  • 举报
回复
应该是游标的效率低
liguiqing 2006-04-30
  • 打赏
  • 举报
回复
程序如下,请大家瞅瞅:
public Object execute() throws SQLException {
List results = null;
String plsql = getPLSQL(plsqlName, params);
LogHelper.logger.info("executeStatement: " + plsql);
Connection cn = null;
CallableStatement cs = null;
try {
cn = getConnection();
cs = cn.prepareCall(plsql);
setParamToStatement(cs, params,true);
 
cs.execute();//1000条数据,就这个调用需要130S,在PL/SQL下测试相同数据量,只要10S

results = parseStatement(cs, params);
} finally {
closeCallable(cs, cn);
}
return results;
jiaojian843 2006-04-30
  • 打赏
  • 举报
回复
应该不是与驱动程序有关,在看看其它的地方。

62,634

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧