SimpleJdbcCall被“多线程”是什么意思?

问题描述

SimpleJdbcCall的文档显示says

SimpleJdbcCall是一个多线程的可重用对象,表示一个 调用存储过程或存储函数。

采用以下代码:

class A{
   
   private SimpleJdbcCall call;

   public void doSomething(){
       call = new SimpleJdbcCall(dataSource).withProcedureName("getColleges");
       SqlParameterSource in = new MapSqlParameterSource().addValue("id",2);
       Map<String,Object> out = jdbcCall.execute(in);
   }

   public void doAnotherThing(){
       call = new SimpleJdbcCall(dataSource).withProcedureName("getClasses");
       SqlParameterSource in = new MapSqlParameterSource().addValue("name","Rahul");
       Map<String,Object> out = jdbcCall.execute(in);
   }

}

现在,假设一个类调用doSomething(),并且变量“ call”已使用过程“ getColleges ”初始化。在控制移至该方法的下一行之前,将doAnotherThing()称为call变量,并将其重新初始化为过程“ getClasses” 。接下来,控件执行doSomething()的下一行并尝试设置id参数,但是由于调用现在与“ getClasses” proc(没有id参数),操作将失败。

“多线程” 是否意味着SimpleJdbcCall不会出现上述竞争条件?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...