Java执行存储过程
生活随笔
收集整理的這篇文章主要介紹了
Java执行存储过程
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
1、JDBC調(diào)用存儲過程: CallableStatement
/** *p是要調(diào)用的存儲過程的名字,存儲過程的4個參數(shù),用4個?號占位符代替 *其余地方寫法固定 */ CallableStatement cstmt = conn.prepareCall("{call p(?,?,?,?)}"); /** *告訴JDBC,這些個參數(shù),哪些是輸出參數(shù),輸出參數(shù)的類型用java.sql.Types來指定 *下面的意思是,第3個?和第4個?是輸出參數(shù),類型是INTEGER的 *Types后面具體寫什么類型,得看你的存儲過程參數(shù)怎么定義的 */ cstmt.registerOutParameter(3, Types.INTEGER); cstmt.registerOutParameter(4, Types.INTEGER); /** *在我這里第1個?和第2個?是輸入?yún)?shù),第3個是輸出參數(shù),第4個既輸入又輸出 *下面是設置他們的值,第一個設為3,第二個設為4,第4個設置為5 *沒設第3個,因為它是輸出參數(shù) */ cstmt.setInt(1, 3); cstmt.setInt(2, 4); cstmt.setInt(4, 5); //執(zhí)行 cstmt.execute(); //把第3個參數(shù)的值當成int類型拿出來 int three = cstmt.getInt(3); System.out.println(three); //把第4個參數(shù)的值當成int類型拿出來 int four = cstmt.getInt(4); System.out.println(four); //用完別忘給人家關(guān)了,后開的先關(guān) cstmt.close(); conn.close();2、JdbcTemplate()調(diào)用存儲過程
getJdbcTemplate().execute(new ConnectionCallback() {@Overridepublic Object doInConnection(Connection con) throws SQLException,DataAccessException {CallableStatement prepareCall = con.prepareCall("{call update "+ "(?)}");prepareCall.setString(1, num);prepareCall.execute();return null;}});?
轉(zhuǎn)載于:https://www.cnblogs.com/x-jingxin/p/9633488.html
總結(jié)
以上是生活随笔為你收集整理的Java执行存储过程的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: dijstra算法
- 下一篇: Java中的servlet是什么?