|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
在1995年5月23日以“Java”的名称正式发布了。
springframework.jdbc.object.StoredProcedure是对应存储历程挪用的操纵对象,它经由过程其父类org.springframework.jdbc.object.SqlCall取得响应的底层API撑持(CallableStatementCreator),然后在此基本之上构建了挪用存储历程的实行办法。
StoredProcedure是笼统类,以是必要完成响应子类以封装对特定存储历程的挪用,还记得我们在解说JdbcTemplate挪用存储历程时分界说的存储历程吗?
CREATEPROCEDURECountTable(INtableNamevarchar(1000),OUTsqlStrvarchar(1000),INOUTvINT)
BEGIN
set@flag=v;
set@sql=CONCAT(selectcount(*)into@resfrom,tableName,whereACTIVE_FLAG=?);
PREPAREstmtFROM@sql;
EXECUTEstmtusing@flag;
DEALLOCATEPREPAREstmt;
setv=@res;
setsqlStr=@sql;
END
经由过程承继StoredProcedure,我们能够为该存储历程的挪用供应一个对应的操纵对象:
publicclassCountTableStoredProcedureextendsStoredProcedure{
privatestaticfinalStringPROCEDURE_NAME="CountTable";
publicstaticfinalStringIN_PARAMETER_NAME="tableName";
publicstaticfinalStringOUT_PARAMETER_NAME="sqlStr";
publicstaticfinalStringINOUT_PARAMETER_NAME="v";
publicCountTableStoredProcedure(DataSourcedataSource)
{
super(dataSource,PROCEDURE_NAME);
//setFunction(true);
declareParameter(newSqlParameter(IN_PARAMETER_NAME,Types.VARCHAR));
declareParameter(newSqlOutParameter(OUT_PARAMETER_NAME,Types.VARCHAR));
declareParameter(newSqlInOutParameter(INOUT_PARAMETER_NAME,Types.INTEGER));
compile();
}
publicCountTableResultdoCountTable(StringtableName,Integerv)
{
MapparaMap=newHashMap();
paraMap.put(IN_PARAMETER_NAME,tableName);
paraMap.put(INOUT_PARAMETER_NAME,v);
MapresultMap=execute(paraMap);
CountTableResultresult=newCountTableResult();
result.setSql((String)resultMap.get(OUT_PARAMETER_NAME));
result.setCount((Integer)resultMap.get(INOUT_PARAMETER_NAME));
returnresult;
}
}
关于该存储历程操纵对象,部分细节我们有需要存眷一下:
存储历程操纵对象对应的SQL是存储历程的称号,而不是真正意义上的SQL语句,当我们挪用compile办法的时分,StoredProcedure的父类SqlCall会依据你供应的存储历程称号拼装真正意义上的切合SQL92尺度的存储历程挪用语句,相似于“{callCountTable(?,?,?)}”的情势。
由于我们的CountTableStoredProcedure只针对CountTable存储历程挪用,以是,该存储历程的称号我们在类一入手下手就声明为常量:
privatestaticfinalStringPROCEDURE_NAME="CountTable";假如有多个存储历程的参数按次不异,了局处置也一样的话,你也能够将存储历程的称号声明为变量,这完整要取决于详细的使用场景。
在机关办法中,我们将“setFunction(true);”正文失落了,由于我们挪用的CountTable不是一个Function,假如你要挪用的存储历程范例为Function的话,你必要经由过程该办法将“function”的值设置为true,以告诉StoredProcedure在处置挪用的时分要区分看待。
在complie之前经由过程declareParameter声明参数,这几近是雷打不动的常规,不外,在StoredProcedure中利用declareParameter的时分却要有所注重了:
<p>
Java编译的是字节码,跟C++相反,启动不够快,效率不够高,难以精确控制内存,但是优点是编程比C++容易,代码比较安全但是容易留下性能隐患,跨平台靠字节码在各个平台复制(一处编译到处调试) |
|