问题描述
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 (将#修改为@)