在PL/SQL中藉助JAVA調用可執行程式的例子

來源:互聯網
上載者:User

/*replace the username*/
call dbms_java.grant_permission( 'FRGT_UAT', 'SYS:java.io.FilePermission', '<<ALL FILES>>', 'execute' );

create or replace java source named "JTns"
as
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.IOException;
public class JTns {
       public static String getfing(String seed){
            /* Note: when this error occured
               ORA-29532: Java call terminated by uncaught Java exception: java.lang.NullPointerException
               just place the full path of the exe
               ex:
               String command = "/home/oracle/product/9.2/bin/tnsping " + seed;
             */
            String command = "tnsping " + seed;
            String pingres = null;           
            Process process;
            InputStreamReader ir = null;
            char c[] = new char[1024];
            try{
                    process = Runtime.getRuntime().exec(command);
                    ir = new InputStreamReader(process.getInputStream());
                    while(ir.read(c, 0, 1024) != -1){
                         pingres = new String(c);
                    }
                    ir.close();
            } catch(IOException io){ }; 
            if (pingres == null) pingres = "Cant Find TNSPING";           
            return pingres.trim();
       }
};
/

create or replace function GetTnsPing(sid varchar2) return varchar2
as language java
name 'JTns.getfing(java.lang.String) return java.lang.String';
/

create or replace function isSeedUp(sid varchar2) return boolean
as
  stat boolean := false;   
  res  varchar2(32767) := gettnsping(sid);
begin
  stat := case
          when instr(res,'OK') > 0 then true
          else false
          end;
  return stat;            
end;
/

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.