关于oracle存储过程调用java(在线等)

关于oracle存储过程调用java(在线等),第1张

1、创建或者代替已有的目录。目录名为test_dir,路径为d:\的目录

2、使用bfile来创建或者代替目录test_dir下的TEST.CLASS的java的类文件

3、败蚂扮查询object_name,object_type,STATUS这三个字段在 user_objects里的数据

4、用java语言调用名称为'TEST.main(java.lang.String[])'来创建或者代替已有的存储察灶过程test_java

其实就是:首先创建一个目录test_dir,路径d:\,然后就在目录名为test_dir下生成test.class(类似于JAVAC这样)然后就创建test_java存储过程,把test.class里物枣面的内容放到到test_java存储过程里面

个人理解,如有误,欢迎指出。

把JAVA程序LOAD进oracle

在$ORACLE_HOME/bin目录下有个LOADJAVA命令,使用这个命令将刚写好的JAVA程序LOAD进数据库。

loadjava -user test/test@test -o -v -f -r Main.java

如果成功的话,会打印出来信息提示成功,若程序正轮有编译错误的话,也会提示你错误的地方。

3。修改权限

因为我的这个JAVA程序里涉及到对文件的读写 *** 作,所以要先修改权限。

首先以管理员身份登录进数据库

sqlplus / as sysdba

然后执行

begin

dbms_java.grant_permission('TEST','SYS:java.io.FilePermission','/var/spool/cron/oracle','read,write,execute,delete')

end

/

执行完毕后,举散信在数据库里执行上述JAVA程序时,就拥有读写该文件的权限了。

4。创建存储掘搭过程

进入到数据库,我是在SQLPLUS命令行

create or replace procedure Modify(name varchar2) as language java name 'Main.modify(java.lang.String)'

/

会提示创建存储过程成功。

5。增加trigger

我是在TOAD里直接针对某个表增加trigger,所以我只写出关键部分的代码

begin

if :old.name = 'time' then

Modify(:new.value)

end if

end

至此,在ORACLE的trigger里调用JAVA程序就完成了,后来的实验证明,每当更新这个表时,都确实执行了该JAVA程序,完成了对文件的读写。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12472028.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存