Oracle使用java source調用外部程式

來源:互聯網
上載者:User

標籤:

需求

Oracle調用第三方外部程式。Oracle使用sqluldr2快速匯出大批量資料,然後用winrar壓縮後發送郵件。

本文檔主要實現前兩步需求,發送郵件程式這裡不再說明。

原碼

授權

begin dbms_java.grant_permission(‘SCOTT‘,‘SYS:java.io.FilePermission‘,‘<<ALL FILES>>‘,‘read,write,execute,delete‘); end;

begin dbms_java.grant_permission(‘SCOTT‘,‘java.lang.RuntimePermission‘,‘*‘,‘writeFileDescriptor‘ ); end;

java source

create or replace and compile java source named jv_run_extpro as

import java.io.*;

import java.lang.*;

import java.util.*;

import java.sql.*;

import oracle.sql.*;

public class jv_run_extpro

{

public static void run(String cmd) throws IOException

{

Process p=Runtime.getRuntime().exec(cmd);

StreamGobbler errorGobbler = new StreamGobbler(p.getErrorStream(), "Error");

StreamGobbler outputGobbler = new StreamGobbler(p.getInputStream(), "Output");

errorGobbler.start();

outputGobbler.start();

try

{

p.waitFor();

}

catch(InterruptedException ie)

{

System.out.println(ie);

}

}

public static class StreamGobbler extends Thread {

?

InputStream is;

String type;

?

public StreamGobbler(InputStream is, String type) {

this.is = is;

this.type = type;

}

?

public void run() {

try {

InputStreamReader isr = new InputStreamReader(is);

BufferedReader br = new BufferedReader(isr);

String line = null;

while ((line = br.readLine()) != null) {

if (type.equals("Error")) {

System.out.println("Error :" + line);

} else {

System.out.println("Debug:" + line);

}

}

} catch (IOException ioe) {

ioe.printStackTrace();

}

}

}

}?

說明:

StreamGobbler這個類不能少,用於非同步讀取命令的輸出。

預存程序

create or replace procedure pro_jv_run_extpro(p_cmd varchar2) as

language java name ‘jv_run_extpro.run(java.lang.String)‘;

調用

begin

pro_jv_run_extpro(‘sqluldr264.exe scott/[email protected] query="select * from emp" field=, head=yes file=D:\Desktop\tmp\sqluldr2\OUT2.TXT‘);

pro_jv_run_extpro(‘"D:\Program Files\WinRAR\Rar.exe" a -ep -df "D:\Desktop\tmp\sqluldr2\20160916.rar" "D:\Desktop\tmp\sqluldr2\OUT2.TXT"‘);

end;

參數說明:

a: 壓縮檔

-ep:包內不顯示壓縮路徑

-df:壓縮後刪除原檔案

總結

程式執行需要授權,如需要查看執行日誌,可在sqlplus下先執行:

Set serveroutput on

Exec dbms_java.set_output(5000);

Oracle使用java source調用外部程式

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.