您的位置:首页 > 数据库 > Oracle

Oracle调用Java外部存储过程

2016-02-01 17:18 495 查看
http://blog.csdn.net/bluelliant/article/details/6333411

1. 编写Java

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

loadjava -u <user>/<passwd>@<tns> -resolve -v <java file>

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

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

dropjava -u <user>/<passwd>@<tns> -v <java file>

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

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

4. 建立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存取文件,需要使用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' );
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: