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中如何調用數據庫的存儲過程。 數據庫

相關文章
相關標籤/搜索