Java执行存储过程
生活随笔
收集整理的這篇文章主要介紹了
Java执行存储过程
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
1、JDBC調(diào)用存儲(chǔ)過(guò)程: CallableStatement
/** *p是要調(diào)用的存儲(chǔ)過(guò)程的名字,存儲(chǔ)過(guò)程的4個(gè)參數(shù),用4個(gè)?號(hào)占位符代替 *其余地方寫法固定 */ CallableStatement cstmt = conn.prepareCall("{call p(?,?,?,?)}"); /** *告訴JDBC,這些個(gè)參數(shù),哪些是輸出參數(shù),輸出參數(shù)的類型用java.sql.Types來(lái)指定 *下面的意思是,第3個(gè)?和第4個(gè)?是輸出參數(shù),類型是INTEGER的 *Types后面具體寫什么類型,得看你的存儲(chǔ)過(guò)程參數(shù)怎么定義的 */ cstmt.registerOutParameter(3, Types.INTEGER); cstmt.registerOutParameter(4, Types.INTEGER); /** *在我這里第1個(gè)?和第2個(gè)?是輸入?yún)?shù),第3個(gè)是輸出參數(shù),第4個(gè)既輸入又輸出 *下面是設(shè)置他們的值,第一個(gè)設(shè)為3,第二個(gè)設(shè)為4,第4個(gè)設(shè)置為5 *沒(méi)設(shè)第3個(gè),因?yàn)樗禽敵鰠?shù) */ cstmt.setInt(1, 3); cstmt.setInt(2, 4); cstmt.setInt(4, 5); //執(zhí)行 cstmt.execute(); //把第3個(gè)參數(shù)的值當(dāng)成int類型拿出來(lái) int three = cstmt.getInt(3); System.out.println(three); //把第4個(gè)參數(shù)的值當(dāng)成int類型拿出來(lái) int four = cstmt.getInt(4); System.out.println(four); //用完別忘給人家關(guān)了,后開(kāi)的先關(guān) cstmt.close(); conn.close();2、JdbcTemplate()調(diào)用存儲(chǔ)過(guò)程
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执行存储过程的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: dijstra算法
- 下一篇: 快速入门系列之 Rust 语言 GitC