需要从具有4个输入变量的过程执行test.ksh,从脚本到过程需要一个输出变量值。在网上找不到这个。任何人都可以建议如何实现。
经过分析我尝试了下面的方法来实现仍然没有运气。在java类下面加载到Oracle DB。
import java.io.BufferedReader;
import java.io.InputStreamReader;
public class KSHCommand {
public static String executeCommand(Long param1,String param2,Long param3, Integer param4) {
StringBuffer output = new StringBuffer();
Process p;
try {
String finalCommand = "Filesystempath/test.ksh";
p = Runtime.getRuntime().exec(finalCommand);
p.waitFor();
BufferedReader reader =
new BufferedReader(new InputStreamReader(p.getInputStream()));
String line = "";
while ((line = reader.readLine())!= null) {
output.append(line + "\n");
}
} catch (Exception e) {
e.printStackTrace();
}
return output.toString();
}
}
out=`/usr/bin/java test`
echo $out
下面是定义用于调用java方法的函数
CREATE OR REPLACE FUNCTION testfun(param1 IN NUMBER,param2 IN VARCHAR2,param3 IN NUMBER,param4 IN NUMBER) RETURN VARCHAR2 AS
LANGUAGE JAVA NAME 'KSHCommand.executeCommand(java.lang.Long, java.lang.String, java.lang.Long,java.lang.Integer) return java.lang.String';
/;
以下是返回空数据的查询
SELECT testfun(5,'test1',6,7) FROM DUAL;
testfun()
------------------------------------------------
如果使用./test.ksh从文件系统执行相同的java文件,将在终端中输出 test 。
如果脚本是从函数执行的话,是否有任何遗漏,请你告诉我。
提前致谢
答案 0 :(得分:1)
使用dbms_scheduler
- 包创建一个包含4个参数的外部作业,传入参数然后运行它。
您可以在https://tinky2jed.wordpress.com/technical-stuff/oracle-stuff/creating-an-oracle-job-that-runs-an-os-executable/或此处找到一个简短且易于理解的简短示例(适用于Windows,但与UX非常相似)https://mikesmithers.wordpress.com/2012/06/12/running-a-windows-batch-file-from-dbms_scheduler/