項目須要使用原生態的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中如何調用數據庫的存儲過程。 數據庫