>  기사  >  데이터 베이스  >  Oracle调用Java外部存储过程

Oracle调用Java外部存储过程

WBOY
WBOY원래의
2016-06-07 17:00:34983검색

1. 编写Java2.使用loadjava导入数据库,loadjava在$ORACLE_HOME/bin下loadjava -u lt;usergt;/lt;passwdgt;@lt;tnsgt; -r

1. 编写Java

2.使用loadjava导入数据库,loadjava在$Oracle_HOME/bin下

loadjava -u /@  -resolve -v

这种方法为把sourcecode也load入数据库

如果之前已经有load过同一个java程序,需要先drop

dropjava -u /@ -v

3.核对java已经导入数据库

select * from user_source where type LIKE 'JAVA%' AND NAME = ''

4. 建立function

CREATE OR REPLACE FUNCTION () RETURN AS
   LANGUAGE JAVA
   NAME '() return java datatype of return variable';

附:

如果需要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', '>', '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', '>', 'execute' );

linux

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.