欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java下使用Oracle存儲(chǔ)過程(詳解)

 更新時(shí)間:2008年09月12日 20:52:00   作者:  
其實(shí),這篇短文,我早就應(yīng)該寫了。因?yàn)椋琷ava存儲(chǔ)過程今后在各大數(shù)據(jù)庫廠商中越來越流行,功能也越來越強(qiáng)大。這里以O(shè)racle為例,介紹一下java存儲(chǔ)過程的具體用法。

二、如何更新你已經(jīng)編寫的java存儲(chǔ)過程?

假如要往類OracleJavaProc里添加一個(gè)存儲(chǔ)過程方法,如何開發(fā)?
正確的步驟應(yīng)該是先dropjava, 改程序,再loadjava。

e.g.修改OracleJavaProc類內(nèi)容如下:

復(fù)制代碼 代碼如下:

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());
}
}

public static int getHiSal(int grade)
...{
try ...{
Connection conn =
DriverManager.getConnection("jdbc:default:connection:");
String sql = "SELECT hisal FROM salgrade WHERE grade = ?";
PreparedStatement pstmt = conn.prepareStatement(sql);pstmt.setInt(1, grade);
ResultSet rset = pstmt.executeQuery();
int res = 0;
if (rset.next())
...{
res = rset.getInt(1);
}
rset.close();
return res;
}
catch (SQLException e)
...{
System.err.println("ERROR! Querying Salgrade: "
+ e.getMessage());
return -1;
}
}

}

如何更新呢?

D:eclipse3.1workspacedbtest>dropjava -u scott -v OracleJavaProc

D:/tiger@iihero.oracledbeclipse3.1workspacedbtest>loadjava -u scott -v -resolve Or
acleJavaProc/tiger@iihero.oracledb.java
arguments: '-u' 'scott/tiger@iihero.oracledb' '-v' '-resolve' 'OracleJavaProc.java'
creating : source OracleJavaProc
loading : source OracleJavaProc
resolving: source OracleJavaProc
后邊的應(yīng)用示例:
復(fù)制代碼 代碼如下:


SQL> create or replace function query_hisal(grade number) return number as langu
age java name 'OracleJavaProc.getHiSal(int) return int';
2 /

函數(shù)已創(chuàng)建。

SQL> set serveroutput on size 2000
SQL> call dbms_java.set_output(2000);

調(diào)用完成。
SQL> select query_hisal(5) from dual;

QUERY_HISAL(5)
--------------
9999
全文完!

用法個(gè)人見解:不要手動(dòng)drop java source, 不要手動(dòng)drop procedure。

相關(guān)文章

最新評(píng)論