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' );
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' );
相关文章推荐
- oracle调用JAVA类的方法
- oracle 分析函数
- ORACLE的一些常用操作
- 取消Oracle用户密码登录错误次数限制
- oracle密码有效期修改为无限制
- 【转】深入解析oracle的回滚段
- oracle的一种字符串处理机制。
- oracle 隐式游标,显示游标,游标循环,动态SELECT语句和动态游标,异常处理,自定义异常
- oracle密码忘记处理对于sys,system情况;
- 这篇很简单,只是一个新手发神经而已。关于oracle的date类型的格式转化。
- navicat for oracle 破解版
- Oracle Essbase入门系列(四)
- win7 64位上Oracle11g数据库的安装,卸载,plsql的安装
- Oracle数据库system用户忘记了密码怎么办
- ORACLE 自动提交问题
- one command 一键收集 oracle 巡检信息(包括dbhc,awr reports)
- Oracle Ebs R12 SLA与GL关系变化
- oracle GoldenGate 值得一学!
- Oracle 笔记
- oracle创建表空间,创建用户,导入dmp数据