项目需要使用原生态的jdbc调用存储过程,写法如下,备忘一下
首先声明一个存储过程
CREATE DEFINER = `root`@`localhost` PROCEDURE `P_SVNTASKADD`(in par1 varchar(1000),in par2 varchar(100),in par3 varchar(200),in par4 varchar(200),in par5 varchar(100),in par6 varchar(2500),out parout int)
begin
insert into svnTask (svnUrl,svnType,developer,dba,createTime,modifyTime,filesNum,filesString,state) values(par1,par2,par3,par4,now(),now(),par5,par6,0);
select MAX(taskId) into parout from svntask;
end;
接下来在java中使用如下代码调用:
String sql = "{call P_SVNTASKADD(?,?,?,?,?,?,?)}";
Object obj = jdbcTemplate.execute(sql,new CallableStatementCallback(){
public Object doInCallableStatement(CallableStatement cs) throws SQLException, DataAccessException {
cs.setString(1,(String) argsForNewTask[0]);
cs.setString(2,(String) argsForNewTask[1]);
cs.setString(3,(String) argsForNewTask[2]);
cs.setString(4,(String) argsForNewTask[3]);
cs.setString(5,(String) argsForNewTask[4]);
cs.setString(6,(String) argsForNewTask[5]);
cs.registerOutParameter("parout", Types.INTEGER);
cs.execute();
return new Integer(cs.getInt("parout"));
}
});
int taskIdResult=((Integer)obj).intValue();
总结一下:本博客主要是备忘一下java中如何调用数据库的存储过程。