需要用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();
  }
}test.ksh
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文件,将在终端中获得输出测试。
如果从函数执行脚本,请告诉我是否遗漏了什么东西。
提前感谢
发布于 2016-04-29 14:41:48
使用dbms_scheduler -包创建一个包含4个参数的外部作业,传入参数,然后运行它。这是一个简短易懂的示例,您可以在这里找到https://tinky2jed.wordpress.com/technical-stuff/oracle-stuff/creating-an-oracle-job-that-runs-an-os-executable/或这里(适用于Windows,但它非常类似于UX) scheduler/
https://stackoverflow.com/questions/36938395
复制相似问题