jdbctemplate调用存储过程

项目须要使用原生态的jdbc调用存储过程,写法以下,备忘一下 java

首先声明一个存储过程 sql

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中如何调用数据库的存储过程。 数据库

相关文章
相关标签/搜索