Chinaunix首页 | 论坛 | 博客
  • 博客访问: 266064
  • 博文数量: 155
  • 博客积分: 2865
  • 博客等级: 少校
  • 技术积分: 1580
  • 用 户 组: 普通用户
  • 注册时间: 2006-03-03 12:34
文章分类

全部博文(155)

文章存档

2010年(2)

2008年(2)

2007年(32)

2006年(119)

我的朋友

分类: Oracle

2007-05-28 18:12:14

//以下运行在sql window
CREATE OR REPLACE AND compile JAVA SOURCE NAMED Utils AS
import java.io.*;
import java.lang.*;
public class Utils extends Object{
 public static int RunThis(String args){
  Runtime rt=Runtime.getRuntime();
  int rc=-1;
  try{
   Process p=rt.exec(args);
   int bufSize=4096;
   BufferedInputStream bis=new BufferedInputStream(p.getInputStream(),bufSize);
   int len;
   byte buffer[]=new byte[bufSize];
   while((len=bis.read(buffer,0,bufSize))!=-1)
    System.out.write(buffer,0,len);
    rc=p.waitFor();
   }catch(Exception e){
    e.printStackTrace();
    rc=-1;
    
   }
   finally{
    return rc;
   }
 
 }
}
 
//以下运行在sqlplus
create or replace function RUN_CMD(p_cmd in varchar2) return number  as language java name 'Utils.RunThis(java.lang.String) return integer';
EXEC Dbms_Java.Grant_Permission('user','java.io.FilePermission', '*','read ,write, execute, delete');
EXEC Dbms_Java.Grant_Permission('user','java.io.FilePermission', 'c:\test.bat','read ,write, execute, delete');
EXEC Dbms_Java.Grant_Permission('user','java.io.FilePermission', 'D:\distrib\runpan.bat','read ,write, execute, delete');
EXEC dbms_java.grant_permission('user','java.lang.RuntimePermission','*','writeFileDescriptor' );

create or replace procedure RC(p_cmd in varchar2) as  x number;
 begin
  x:=run_cmd(p_cmd);
 if(x<>0)
 then
    raise program_error;
 end if;
 end;
/
variable x number;
set serveroutput on
exec dbms_java.set_output(100000);
 
//可以在触发器调用
 exec :x := RUN_CMD('D:\distrib\runpan.bat');
阅读(1329) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~