Oracle触发器反向调用Java程序

导入jar包
在oracle中导入需要的jar包,我们把编辑好的java类打成jar包,直接在oarcle里面写简单的调用就可以了,
 1、操作系统需要拥有支持loadjava命令的jdk。
 2、加载jlha.jar包,到oracle数据库中。
    操作过程:在dos环境下,输入命令: loadjava   -r   -f   -o   -user   usscares/[email protected]   jlha.jar
注意:jar包要在1.4的环境下编译,项目右键 properties java compiler compoler compliance level 1.4 即可   否则报version 49 类似的错误
调用JAVA类
oracle调用JAVA类的方法主要有以下三种:

用loadjava方法装载;
可能是调试方便,据说这种方法比较通用。
c:\test\hello.java
public class hello
{

    public static void main(String[] args)
    {
        System.out.println("Hello");
        hello h = new hello();
        h.insertM(9);
    }
    public static void insertM(int pid)
    {
        System.out.println("This is the method insertM.");
    }
}

 C:\test>loadjava -u test/[email protected] -v -resolve hello.java

SQL> create procedure prc_hehe as language java name ‘hello.main(java.lang.String[])

过程已创建。

SQL> call prc_hehe();

调用完成。

SQL> set serveroutput on size 2000
SQL> call prc_hehe();

调用完成。

SQL> exec dbms_java.set_output(2000);

PL/SQL 过程已成功完成。

SQL> call prc_hehe();
Hello
This is the method insertM.

调用完成。

SQL>show errors;

修改java类,先删除再装载,方法:

dropjava -u test/[email protected] -v -resolve hello.java

loadjava -u test/[email protected] -v -resolve hello.java

用sql语句创建
create or replace and compile java source named hehe
AS
public class hello
{
    public static void msg(String name)
    {
        System.out.println("hello," + name);
    }
};

create or replace procedure prc_hehe
(
       p_name VARCHAR2
)
as
language java name ‘hello.msg(java.lang.String)‘;

-- 调用结果

SQL> call prc_hehe(‘oopp‘);
hello,oopp

用外部class文件来装载创建
create or replace directory CLASS_DIR  as ‘c:\test‘;

create or replace java class using bfile(class_dir,‘hello.class‘);

create or replace procedure prc_hello
(
       p_name VARCHAR2
)
as
language java name ‘hello.msg(java.lang.String)‘;

-- 测试结果

SQL> call prc_hello(‘java‘);
java

可能出现的错误
SQL> call prc_hello(‘Jerry‘);
call prc_hello(‘Jerry‘)
     *
第 1 行出现错误:
ORA-29516: Aurora 断言失败: Assertion failure at eox.c:359
Uncaught exception System error:   java/lang/UnsupportedClassVersionError

原因:机器装了多个java版本,oracle的java版本低于环境变量设置的版本。

解决方法:用$ORACLE_HOME/jdk/javac 重新编译java文件

核对java已经导入数据库

select * from user_source where type LIKE ‘JAVA%‘ AND NAME = ‘<java file>‘

建立function

CREATE OR REPLACE FUNCTION <FUNCTION_NAME> (<PARAMETER LIST IN ORACLE DATATYPE>) RETURN <ORACLE DATATYPE OF RETURN VARIABLE> AS
   LANGUAGE JAVA
   NAME ‘<clase.method>(<parameter list in java datatype>) return java datatype of return variable‘;

 例:

登陆某一用户登录,并创建java程序资源,在pl/sql中java source中显示你所编写的java代码;
create or replace and compile java source named bb_wx_replosssbk as
import java.sql.*;
import oracle.jdbc.driver.*;

public class bb_wx_replosssbk
{
    /**
    *   社保卡挂失
    */
    public static String callProc(String sSfzh, String sPwd, String sType)
    {
        OracleDriver driver = new OracleDriver();
        Connection connection = null;
        CallableStatement cstmt = null;
        String sRtn = "beg";
        try
        {
            sRtn = " try beg";
            connection = DriverManager.getConnection("jdbc:oracle:thin:user/[email protected]:1521:orcl");
            sRtn = "con";
            cstmt = connection.prepareCall("{call run_replosssbk(?,?,?,?)}");
            sRtn = "invoke";
            cstmt.setString(1, sSfzh);
            cstmt.setString(2, sPwd);
            cstmt.setString(3, sType);
            cstmt.registerOutParameter(4, java.sql.Types.VARCHAR);
            sRtn = "set value";
            cstmt.executeUpdate();
            sRtn = "execute";
            sRtn = cstmt.getString(4);
        }
        catch (Exception e)
        {
            sRtn = e.toString();
            e.printStackTrace();
        }
        finally
        {
            try
            {
                if (cstmt != null)
                {
                    cstmt.close();
                }
                if (connection != null)
                {
                    connection.close();
                }
            }
            catch (Exception e)
            {
                e.printStackTrace();
            }
        }
        return sRtn;
    }
}

创建调用Java资源的函数
create or replace function run_bb_wx_replosssbk(
sSfz in varchar2,
sPwd in varchar2,
sType in varchar2
)
return varchar2
as
language java name ‘bb_wx_replosssbk.callProc(java.lang.String,java.lang.String,java.lang.String) return java.lang.String‘;

建立一过程调用存储过程
create or replace procedure RUN(
sSfz in varchar2,
sPwd in varchar2,
sType in varchar2
sRtn out varchar2
)
as
begin
--sRtn := run_bb_wx_replosssbk(sSfz in varchar2,sPwd in varchar2,sType in varchar2);
Select run_bb_wx_replosssbk(sSfz in varchar2,sPwd in varchar2,sType in varchar2)
Into sRtn from dual;
end;
/

附:

如果需要java存取文件,需要使用dba用户赋权

EXEC Dbms_Java.Grant_Permission(‘ONBOARDING‘, ‘SYS:java.lang.RuntimePermission‘, ‘writeFileDescriptor‘, ‘‘);
EXEC Dbms_Java.Grant_Permission(‘ONBOARDING‘, ‘SYS:java.lang.RuntimePermission‘, ‘readFileDescriptor‘, ‘‘);
EXEC dbms_java.grant_permission( ‘ONBOARDING‘, ‘SYS:java.io.FilePermission‘, ‘<<ALL FILES>>‘, ‘execute‘ );
收回权限的语句如下

EXEC Dbms_Java.revoke_Permission(‘ONBOARDING‘, ‘SYS:java.lang.RuntimePermission‘, ‘writeFileDescriptor‘, ‘‘);
EXEC Dbms_Java.revoke_Permission(‘ONBOARDING‘, ‘SYS:java.lang.RuntimePermission‘, ‘readFileDescriptor‘, ‘‘);
EXEC dbms_java.revoke_permission( ‘ONBOARDING‘, ‘SYS:java.io.FilePermission‘, ‘<<ALL FILES>>‘, ‘execute‘ );
时间: 2024-08-25 03:28:49

Oracle触发器反向调用Java程序的相关文章

在ORACLE触发器里调用JAVA程序

因为项目需要,有一个已经写好的Java程序,想要在Oracle某个表的触发器中调用,以使得每次数据更新时,调用这个JAVA程序,来修改后台某个数据. 现将过程记录如下: 1.编写JAVA程序 [java] view plain copy public class Main { public static void modify(String statTime) { String datas = "/var/spool/cron/oracle"; File data = new File

C通过JNI反向调用JAVA程序方法

JNI反向调用JAVA程序 引述:上文讲过java线程---OS线程的关系,然后C怎样反向调用JAVA程序方法是我们这篇讲的重点 1.ThreadTest中添加run()方法 2.编译ThreadTest.java         javac ThreadTest.java    生成ThreadTest.class 3.javah ThreadTest    生成 ThreadTest.h文件 4.编写ThreadNew.c文件 #include<pthread.h>#include<

Oracle触发器如何调用Java实现Openfire消息发送

写在前面,要想实现整个过程的成功执行请先准备以下文件: 1. 登陆Openfire服务端以及Spark客户端相关程序(openfire_4_0_1.exe.spark_2_7_6.exe) 2. 连接Openfire和Oracle相关的jar包(presence.jar.smack.jar.smackx-debug.jar.smackx.jar.ojdbc.jar)  Step1:安装Openfire服务端并配置数据库连接,配置参考<Openfire服务器安装与配置教程> Step2:在Ecl

Oracle数据库中调用Java类开发存储过程、函数的方法

Oracle数据库中调用Java类开发存储过程.函数的方法 时间:2014年12月24日  浏览:5538次 oracle数据库的开发非常灵活,不仅支持最基本的SQL,而且还提供了独有的PL/SQL,除此之外,还可以用时下最流行的编程语言Java来做开发.随着对oracle的了解越来越多,越来越禁不住oracle的诱惑,oracle技术真的是一门很有趣的学问.之前,我在博客中总结了挺多有关SQL.PL/SQL的,但是对于oracle数据库中Java类的调用却没有总结,也是因为之前不太会,这会儿总

python调用java程序--jpype

官方网站:http://jpype.sourceforge.net/ 官方使用文档:http://jpype.sourceforge.net/doc/user-guide/userguide.html 1.安装 首先在官网上下载程序安装包 ubuntu系统可以直接通过 sudo apt-get install python-jpype 命令安装 ,但是因为会附带安装open-jdk pass  ,手动安装jdk,然后再安装jpype 解压目录 切换到setup.py 目录执行 sudo pyth

LoadRunner调用Java程序—性能测试-转载

LoadRunner调用Java程序-性能测试 为了充分利用LoadRunner的场景控制和分析器,帮助我们更好地控制脚本加载过程,从而展现更直观有效的场景分析图表.本次将重点讨论LoadRunner如何调用Java测试代码,完成压力测试. 通常我们在执行一些Server的压力测试的时候,总会不经意间想要一个Client完成对Server的调用示例,以至于我们可以通过LoadRunner直接录制,对于测试人员来说确实很方便.不过,开发人 员如果没有那么多时间去为测试人员服务,那可能就比较悲剧了,

定时cronjob调用Java程序

一个部署在linux环境的Java企业应用后台经常会在大半夜运行很多定时的任务,本篇文章总结下如何使用shell脚本调用Java程序,以备忘. 1. setupenv.sh export APP_HOME=`pwd` if [ -z "$JAVA_HOME" ] ; then JAVA=`which java` if [ -z "$JAVA" ] ; then echo "Cannot find JAVA. Please set your PATH.&qu

oracle触发器调用java程序

1.创建java程序:接收存储过程传递的参数,发送socket通信. create or replace and compilejava source named jym as import java.io.BufferedReader; import java.io.InputStream; importjava.io.InputStreamReader; import java.io.OutputStream; import java.io.StringWriter; importjava.

oracle中触发器调用Java程序

1. 写一个Java程序,Java程序的目录是:E:\APP\test\src\test\Main.java 2. 在环境变量Path中配置,E:\studyInstallPath\oracle\BIN 3. 在E:\APP\test\src\test这个目录下执行 4. 5. 创建存储过程 create or replace procedure testmodify(name varchar2) as language Java name 'Main.modify(java.lang.Stri