本文主要介绍的是如何在Oracle数据库里使用Java存储过程,本文以Oracle为例,来介绍一下java存储过程的实际具体用法。 以下是文章的具体介绍,望你浏览完以下的内容会有所收获。
一、如何创建java存储过程?
通常有三种方法来创建java存储过程。
1. 使用Oracle的sql语句来创建:
e.g. 使用
- create or replace and compile java source named "" as
后边跟上java源程序。要求类的方法必须是public static的,才能用于存储过程。
- SQL> create or replace and compile java source
named "javademo1"- as
- import java.sql.*;
- public class JavaDemo1
- {
- public static void main(String[] argv)
- {
- System.out.println("hello, java demo1");
- }
- }
- /
Java 已创建
- SQL> show errors java source "javademo1"
没有错误。
- SQL> create or replace procedure javademo1
- as
- language java name 'JavaDemo1.main(java.lang.String[])';
- /
过程已创建
- SQL> set serveroutput on
- SQL> call javademo1();
调用完成
- SQL> call dbms_java.set_output(5000);
调用完成
- SQL> call javademo1();
- hello, java demo1
调用完成。
- SQL> call javademo1();
- hello, java demo1
调用完成。
2.使用外部class文件来装载创建
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;
授权成功
- SQL> conn scott/tiger@iihero.oracledb
已连接。
- SQL> create or replace directory test_dir as 'd:\oracle';
目录已创建
- SQL> create or replace java class using bfile
(test_dir, 'OracleJavaProc.CLASS')- 2 /
Java 已创建。
- SQL> create or replace procedure testjavaproc as
language java name 'OracleJavaProc.main
(java.lang.String[])';- 2 /
过程已创建。
- SQL> call testjavaproc();
调用完成。
- SQL> execute testjavaproc;
PL/SQL 过程已成功完成。
- SQL> set serveroutput on size 5000
- SQL> call dbms_java.set_output(5000);
调用完成
- SQL> execute testjavaproc;
- It's a Java Oracle procedure.
以上的相关内容就是对如何在Oracle数据库里使用Java存储过程的相关介绍,望你能有所收获。
【编辑推荐】