试图从plsql程序

时间:2016-04-29 12:29:30

标签: plsql oracle11g ksh plsqldeveloper database-administration

需要从具有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文件,将在终端中输出 test

如果脚本是从函数执行的话,是否有任何遗漏,请你告诉我。

提前致谢

1 个答案:

答案 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/