JAVA調(diào)用Oracle存儲(chǔ)過程的實(shí)現(xiàn)方法
JAVA跟Oracle之間,最常用的操作就是是JAVA調(diào)用Oracle存儲(chǔ)過程,下面就為您介紹JAVA如何對(duì)Oracle存儲(chǔ)過程進(jìn)行調(diào)用。
Ⅰ、JAVA調(diào)用Oracle存儲(chǔ)過程【不帶輸出參數(shù)】
過程名稱為pro1,參數(shù)個(gè)數(shù)1個(gè),數(shù)據(jù)類型為整形數(shù)據(jù)。
- import java.sql.*;
- public class ProcedureNoArgs {
- public static void main(String args[]) throws Exception {
- // 加載Oracle驅(qū)動(dòng)
- DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());
- // 獲得Oracle數(shù)據(jù)庫連接
- Connection conn = DriverManager.getConnection(
- " jdbc:oracle:thin:@MyDbComputerNameOrIP:1521:ORCL", sUsr, sPwd);
- // 創(chuàng)建存儲(chǔ)過程的對(duì)象
- CallableStatement c = conn.prepareCall(" {call pro1(?)} ");
- // 給Oracle存儲(chǔ)過程的參數(shù)設(shè)置值 ,將第一個(gè)參數(shù)的值設(shè)置成188
- c.setInt(1, 188);
- // 執(zhí)行Oracle存儲(chǔ)過程
- c.execute();
- conn.close();
- }
- }
Ⅱ、JAVA調(diào)用Oracle存儲(chǔ)過程【帶輸出參數(shù)的情況】
過程名稱為pro2,參數(shù)個(gè)數(shù)2個(gè),數(shù)據(jù)類型為整形數(shù)據(jù),返回值為整形類型
- import java.sql.*;
- public class ProcedureWithArgs {
- public static void main(String args[]) throws Exception {
- // 加載Oracle驅(qū)動(dòng)
- DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());
- // 獲得Oracle數(shù)據(jù)庫連接
- Connection conn = DriverManager.getConnection(
- "jdbc:oracle:thin:@MyDbComputerNameOrIP:1521:ORCL", sUsr, sPwd);
- // 創(chuàng)建Oracle存儲(chǔ)過程的對(duì)象,調(diào)用存儲(chǔ)過程
- CallableStatement c = conn.prepareCall("{call pro2(?,?)}");
- // 給Oracle存儲(chǔ)過程的參數(shù)設(shè)置值 ,將第一個(gè)參數(shù)的值設(shè)置成188
- c.setInt(1, 188);
- // 注冊(cè)存儲(chǔ)過程的第二個(gè)參數(shù)
- c.registerOutParameter(2, java.sql.Types.INTEGER);
- // 執(zhí)行Oracle存儲(chǔ)過程
- c.execute();
- // 得到存儲(chǔ)過程的輸出參數(shù)值并打印出來
- System.out.println(c.getInt(2));
- conn.close();
- }
- }
以上即是在JAVA中調(diào)用Oracle存儲(chǔ)過程的最簡(jiǎn)單的實(shí)例。
【編輯推薦】