Java下使用Oracle存儲過程(詳解)第1/3頁
更新時間:2008年09月12日 20:52:00 作者:
其實(shí),這篇短文,我早就應(yīng)該寫了。因?yàn)?,java存儲過程今后在各大數(shù)據(jù)庫廠商中越來越流行,功能也越來越強(qiáng)大。這里以O(shè)racle為例,介紹一下java存儲過程的具體用法。
任何轉(zhuǎn)載,請尊重版權(quán)。(作者:iihero on csdn)
一、如何創(chuàng)建java存儲過程?
通常有三種方法來創(chuàng)建java存儲過程。
1. 使用oracle的sql語句來創(chuàng)建:
e.g. 使用create or replace and compile java source named "<name>" as
后邊跟上java源程序。要求類的方法必須是public static的,才能用于存儲過程。
SQL> create or replace and compile java source named "javademo1"
2 as
3 import java.sql.*;
4 public class JavaDemo1
5 {
6 public static void main(String[] argv)
7 {
8 System.out.println("hello, java demo1");
9 }
10 }
11 /
Java 已創(chuàng)建。
SQL> show errors java source "javademo1"
沒有錯誤。
SQL> create or replace procedure javademo1
2 as
3 language java name 'JavaDemo1.main(java.lang.String[])';
4 /
過程已創(chuàng)建。
SQL> set serveroutput on
SQL> call javademo1();
調(diào)用完成。
SQL> call dbms_java.set_output(5000);
調(diào)用完成。
SQL> call javademo1();
hello, java demo1
調(diào)用完成。
SQL> call javademo1();
hello, java demo1
調(diào)用完成。
2. 使用外部class文件來裝載創(chuàng)建
e.g. 這里既然用到了外部文件,必然要將class文件放到oracle Server的某一目錄下邊。
public class OracleJavaProc
{
public static void main(String[] argv)
{
System.out.println("It's a Java Oracle procedure.");
}
}
SQL> grant create any directory to scott;
授權(quán)成功。
SQL> conn scott/tiger@iihero.oracledb
已連接。
SQL> create or replace directory test_dir as 'd:\oracle';
目錄已創(chuàng)建。
SQL> create or replace java class using bfile(test_dir, 'OracleJavaProc.CLASS')
2 /
Java 已創(chuàng)建。
SQL> create or replace procedure testjavaproc as language java name 'OracleJavaProc.main(java.lang.String[])';
2 /
過程已創(chuàng)建。
SQL> call testjavaproc();
調(diào)用完成。
SQL> execute testjavaproc;
PL/SQL 過程已成功完成。
SQL> set serveroutput on size 5000
SQL> call dbms_java.set_output(5000);
調(diào)用完成。
SQL> execute testjavaproc;
It's a Java Oracle procedure.
一、如何創(chuàng)建java存儲過程?
通常有三種方法來創(chuàng)建java存儲過程。
1. 使用oracle的sql語句來創(chuàng)建:
e.g. 使用create or replace and compile java source named "<name>" as
后邊跟上java源程序。要求類的方法必須是public static的,才能用于存儲過程。
復(fù)制代碼 代碼如下:
SQL> create or replace and compile java source named "javademo1"
2 as
3 import java.sql.*;
4 public class JavaDemo1
5 {
6 public static void main(String[] argv)
7 {
8 System.out.println("hello, java demo1");
9 }
10 }
11 /
Java 已創(chuàng)建。
SQL> show errors java source "javademo1"
沒有錯誤。
SQL> create or replace procedure javademo1
2 as
3 language java name 'JavaDemo1.main(java.lang.String[])';
4 /
過程已創(chuàng)建。
SQL> set serveroutput on
SQL> call javademo1();
調(diào)用完成。
SQL> call dbms_java.set_output(5000);
調(diào)用完成。
SQL> call javademo1();
hello, java demo1
調(diào)用完成。
SQL> call javademo1();
hello, java demo1
調(diào)用完成。
2. 使用外部class文件來裝載創(chuàng)建
e.g. 這里既然用到了外部文件,必然要將class文件放到oracle Server的某一目錄下邊。
復(fù)制代碼 代碼如下:
public class OracleJavaProc
{
public static void main(String[] argv)
{
System.out.println("It's a Java Oracle procedure.");
}
}
SQL> grant create any directory to scott;
授權(quán)成功。
SQL> conn scott/tiger@iihero.oracledb
已連接。
SQL> create or replace directory test_dir as 'd:\oracle';
目錄已創(chuàng)建。
SQL> create or replace java class using bfile(test_dir, 'OracleJavaProc.CLASS')
2 /
Java 已創(chuàng)建。
SQL> create or replace procedure testjavaproc as language java name 'OracleJavaProc.main(java.lang.String[])';
2 /
過程已創(chuàng)建。
SQL> call testjavaproc();
調(diào)用完成。
SQL> execute testjavaproc;
PL/SQL 過程已成功完成。
SQL> set serveroutput on size 5000
SQL> call dbms_java.set_output(5000);
調(diào)用完成。
SQL> execute testjavaproc;
It's a Java Oracle procedure.
您可能感興趣的文章:
- Java Spring動態(tài)生成Mysql存儲過程詳解
- 詳解java調(diào)用存儲過程并封裝成map
- MyBatis創(chuàng)建存儲過程的實(shí)例代碼_動力節(jié)點(diǎn)Java學(xué)院整理
- Java調(diào)用Oracle存儲過程詳解
- Java實(shí)現(xiàn)調(diào)用MySQL存儲過程詳解
- 詳解Java的JDBC API的存儲過程與SQL轉(zhuǎn)義語法的使用
- java編程調(diào)用存儲過程中得到新增記錄id號的實(shí)現(xiàn)方法
- Java調(diào)用MySQL存儲過程并獲得返回值的方法
- java調(diào)用mysql存儲過程實(shí)例分析
- Java中調(diào)用SQL Server存儲過程詳解
- java調(diào)用oracle分頁存儲過程示例
- java調(diào)用Oracle存儲過程的方法實(shí)例
- Java存儲過程調(diào)用CallableStatement的方法
相關(guān)文章
實(shí)例解析JSP中EL表達(dá)式的各種運(yùn)用
這篇文章主要介紹了JSP中EL表達(dá)式的各種運(yùn)用,比如用EL處理數(shù)學(xué)運(yùn)算、內(nèi)置對象以及數(shù)據(jù)的存取等,代碼示例都相當(dāng)實(shí)用,需要的朋友可以參考下2016-04-04用fileupload組件實(shí)現(xiàn)的大文件上傳簡單實(shí)例
下面小編就為大家?guī)硪黄胒ileupload組件實(shí)現(xiàn)的大文件上傳簡單實(shí)例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10JavaWeb實(shí)現(xiàn)圖形報(bào)表折線圖的方法
這篇文章主要介紹了JavaWeb實(shí)現(xiàn)圖形報(bào)表折線圖的方法,涉及JSP包的引用、圖形操作、配置文件設(shè)置及字符串操作技巧,需要的朋友可以參考下2016-06-06jsp利用POI生成Excel并在頁面中導(dǎo)出的示例
本篇文章主要是介紹jsp利用POI生成Excel并在頁面中導(dǎo)出的示例,具有一定的參考價值,感興趣的小伙伴們可以參考一下。2016-10-10JSP Session超時設(shè)置的實(shí)現(xiàn)方法
這篇文章主要介紹了JSP Session超時設(shè)置的實(shí)現(xiàn)方法的相關(guān)資料,這里提供三種方法幫助大家學(xué)習(xí)理解這部分內(nèi)容,需要的朋友可以參考下2017-09-09