/** * @Auther: zml * @Date: 2018/6/8 */ import org.springframework.jdbc.core.CallableStatementCallback; import org.springframework.jdbc.core.CallableStatementCreator; import org.springframework.jdbc.core.JdbcTemplate; import java.sql.CallableStatement; import java.sql.Connection; import java.sql.SQLException; import java.sql.Types; import java.util.ArrayList; import java.util.List; /** * @Auther: zml * @Date: 2018/6/8 */ public class Test { private JdbcTemplate jdbcTemplate; public JdbcTemplate getJdbcTemplate() { return jdbcTemplate; } public void setJdbcTemplate(JdbcTemplate jdbcTemplate) { this.jdbcTemplate = jdbcTemplate; } //調用存儲過程,一個輸入參數,三個輸出 public List<String> callPro(String str){ //final String str = str.toString(); List<String> resList = (List)jdbcTemplate.execute( new CallableStatementCreator(){ @Override public CallableStatement createCallableStatement(Connection connection) throws SQLException { String storedPro = "{call KPI.CHECK_SITUATION(?,?,?,?)}"; CallableStatement cs = connection.prepareCall(storedPro); cs.setString(1, str); //輸出參數類型 cs.registerOutParameter(2, Types.INTEGER); cs.registerOutParameter(3, Types.VARCHAR); cs.registerOutParameter(4, Types.VARCHAR); return cs; } },(cs)->{ cs.execute(); List<String> list = new ArrayList<String>(); list.add(cs.getInt(2)+""); list.add(cs.getString(3)); list.add(cs.getString(4)); return list ; } ); return resList; } public static void xxmain(String[] args){ Test t = new Test(); //調用存儲過程,傳一個空的字符串 t.callPro(""); } }