Java下使用Oracle存儲過程(詳解)第2/3頁
更新時間:2008年09月12日 20:52:00 作者:
其實,這篇短文,我早就應該寫了。因為,java存儲過程今后在各大數據庫廠商中越來越流行,功能也越來越強大。這里以Oracle為例,介紹一下java存儲過程的具體用法。
3. 我推薦的一種方法,直接使用loadjava命令遠程裝載并創(chuàng)建。
先創(chuàng)建一個類, e.g.
復制代碼 代碼如下:
import java.sql.*;
import oracle.jdbc.*;
public class OracleJavaProc ...{
//Add a salgrade to the database.
public static void addSalGrade(int grade, int losal, int hisal) ...{
System.out.println("Creating new salgrade for EMPLOYEE...");
try ...{
Connection conn =
DriverManager.getConnection("jdbc:default:connection:");
String sql =
"INSERT INTO salgrade " +
"(GRADE,LOSAL,HISAL) " +
"VALUES(?,?,?)";
PreparedStatement pstmt = conn.prepareStatement(sql);
pstmt.setInt(1,grade);
pstmt.setInt(2,losal);
pstmt.setInt(3,hisal);
pstmt.executeUpdate();
pstmt.close();
}
catch(SQLException e) ...{
System.err.println("ERROR! Adding Salgrade: "
+ e.getMessage());
}
}
}
使用loadjava命令將其裝載到服務器端并編譯:
復制代碼 代碼如下:
D:eclipse3.1workspacedbtest>loadjava -u scott/tiger@iihero.oracledb -v -resolve Or
acleJavaProc.java
arguments: '-u' 'scott/tiger@iihero.oracledb '-v' '-resolve' 'OracleJavaProc.java'
creating : source OracleJavaProc
loading : source OracleJavaProc
resolving: source OracleJavaProc
查詢一下狀態(tài):
連接到:
Oracle9i Enterprise Edition Release 9.2.0.1.0 - Production
With the Partitioning, OLAP and Oracle Data Mining options
JServer Release 9.2.0.1.0 - Production
復制代碼 代碼如下:
SQL> SELECT object_name, object_type, status FROM user_objects WHERE object_type LIKE 'JAVA%';
OBJECT_NAME
--------------------------------------------------------------------------------
OBJECT_TYPE STATUS
------------------------------------ --------------
OracleJavaProc
JAVA CLASS VALID
OracleJavaProc
JAVA SOURCE VALID
測試一下存儲過程:
復制代碼 代碼如下:
SQL> create or replace procedure add_salgrade(id number, losal number, hisal num
ber) as language java name 'OracleJavaProc.addSalGrade(int, int, int)';
2 /
過程已創(chuàng)建。
SQL> set serveroutput on size 2000
SQL> call dbms_java.set_output(2000);
調用完成。
SQL> execute add_salgrade(6, 10000, 15000);
Creating new salgrade for EMPLOYEE...
PL/SQL 過程已成功完成。
SQL> select * from salgrade where grade=6;
GRADE LOSAL HISAL
---------- ---------- ----------
6 10000 15000
您可能感興趣的文章:
- Java Spring動態(tài)生成Mysql存儲過程詳解
- 詳解java調用存儲過程并封裝成map
- MyBatis創(chuàng)建存儲過程的實例代碼_動力節(jié)點Java學院整理
- Java調用Oracle存儲過程詳解
- Java實現調用MySQL存儲過程詳解
- 詳解Java的JDBC API的存儲過程與SQL轉義語法的使用
- java編程調用存儲過程中得到新增記錄id號的實現方法
- Java調用MySQL存儲過程并獲得返回值的方法
- java調用mysql存儲過程實例分析
- Java中調用SQL Server存儲過程詳解
- java調用oracle分頁存儲過程示例
- java調用Oracle存儲過程的方法實例
- Java存儲過程調用CallableStatement的方法
相關文章
JSP中動態(tài)include與靜態(tài)include的區(qū)別介紹
動態(tài)include與靜態(tài)include的區(qū)別你知道嗎,下面就詳細為大家詳細介紹下,如果你還不知道那么不要錯過2013-11-11
response.getWriter().write()向前臺打印信息亂碼問題解決
本節(jié)主要介紹了response.getWriter().write()向前臺打印信息亂碼問題解決方法,需要的朋友可以參考下2014-08-08
asp.net getRemoteAddr()與 getRemoteHost()的區(qū)別
getRemoteAddr()與 getRemoteHost()的區(qū)別小結,需要的朋友可以參考下。2009-12-12

