oracle执行cmd的实现方法

 更新时间:2009年04月20日 14:51:39   作者:  
装了一个oracle db11g,于是想试一下网上流传的在sqlplus中执行cmd的一些命令,也不知怎么的,没一个好用的,可能是网上转来转去的转错了.
不过有一个简单的执行cmd命令方法:
SQL> host net user
User accounts for \\PC-ATQHJ4UG1SDA
----------------------------------------------------------------------------
__vmware_user__ admin Administrator
ASPNET Guest IUSR_PC-ATQHJ4UG1SDA
IWAM_PC-ATQHJ4UG1SDA SUPPORT_388945a0
The command completed successfully.
unix或linux下用
! command
======================补充======================
网上的另两种方法:
1是利用msvcrt.dll
写一个c:\orac.sql
内容:
Rem
Rem oracmd.sql
Rem
Rem Run system commands via Oracle database servers
Rem
Rem Bugs to david@ngssoftware.com
Rem
CREATE OR REPLACE LIBRARY exec_shell AS
'C:\windows\system32\msvcrt.dll';
/
show errors
CREATE OR REPLACE PACKAGE oracmd IS
PROCEDURE exec (cmdstring IN CHAR);
end oracmd;
/
show errors
CREATE OR REPLACE PACKAGE BODY oracmd IS
PROCEDURE exec(cmdstring IN CHAR)
IS EXTERNAL
NAME "system" LIBRARY exec_shell
LANGUAGE C;
end oracmd;
/
show errors
然后C:\>sqlplus /nolog
SQL*Plus: Release 8.1.7.0.0 - Production on Thu Jun 7 14:25:38 2001
(c) Copyright 2000 Oracle Corporation. All rights reserved.
SQL> connect system/manager@orcl (分别是用户名密码和sid)
Connected.
SQL> @c:\orac.sql
Library created.
No errors.
Package created.
No errors.
Package body created.
No errors.
SQL>
SQL> exec oracmd.exec ('dir > c:\oracle.txt');
结果在我本机出现
第 1 行出现错误:
ORA-28595: Extproc 代理: DLL 路径无效
ORA-06512: 在 "SYSTEM.ORACMD", line 2
ORA-06512: 在 line 1
没有成功。
第二种方法
c:\1.sql
create or replace and compile
java souRCe named "util"
as
import java.io.*;
import java.lang.*;
public class util 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];
// Echo back what the program spit out
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;
}
}
}
c:\2.sql
create or replace
function RUN_CMz(p_cmd in varchar2) return number
as
language java
name 'util.RunThis(java.lang.String) return integer';
c:\3.sql
create or replace procedure RC(p_cmd in varChar)
as
x number;
begin
x := RUN_CMz(p_cmd);
end;
登陆上去后依旧是依次执行
SQL> @c:\1.sql
/
@c:\2.sql
/
@c:\3.sql
/
variable x number;
set serveroutput on;
exec dbms_java.set_output(100000);
grant javasyspriv to system;
grant javauserpriv to system;(网上的方法没有这一行,我无法成功,加上去可以)
exec :x:=run_cmz('ipconfig'); 成功运行了命令
测试环境win2003+oracle11g

相关文章

  • orcale中的to_number方法使用

    orcale中的to_number方法使用

    这篇文章主要介绍了orcale中的to_number方法使用,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • Oracle中日期的使用方法实例

    Oracle中日期的使用方法实例

    oracle数据类型看起来非常简单,但用起来会发现有许多知识点,下面这篇文章主要给大家介绍了关于Oracle中日期使用方法的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2022-07-07
  • oracle中函数 trunc(),round(),ceil(),floor的使用详解

    oracle中函数 trunc(),round(),ceil(),floor的使用详解

    这篇文章主要介绍了oracle中函数 trunc(),round(),ceil(),floor的使用详解的相关资料,需要的朋友可以参考下
    2017-03-03
  • oracle导出sql语句的结果集和保存执行的sql语句(深入分析)

    oracle导出sql语句的结果集和保存执行的sql语句(深入分析)

    本篇文章是对oracle导出sql语句的结果集与保存执行的sql语句进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • Oracle exadata存储节点更换内存操作及报错处理方法

    Oracle exadata存储节点更换内存操作及报错处理方法

    在进行Oracle Exadata巡检时,发现cell节点内存报错,需确认内存PN号及大小,并更换备件,这篇文章主要介绍了Oracle exadata存储节点更换内存操作及报错处理的相关资料,需要的朋友可以参考下
    2024-10-10
  • Oracle创建带有参数的视图代码介绍

    Oracle创建带有参数的视图代码介绍

    这篇文章主要介绍了Oracle创建带有参数的视图代码介绍,简介地介绍了创建方法,具有一定参考价值,需要的朋友可以了解下。
    2017-09-09
  • Oracle 11G数据库审计监控设置指南

    Oracle 11G数据库审计监控设置指南

    Oracle 11G数据库审计监控涉及创建独立表空间、查看审计信息、迁移表空间、开启审计及审计维护等步骤,合理规划审计表空间有助于管理审计数据,避免影响系统表空间,审计监控涵盖审计数据迁移、自动清理、权限分配、查询审计类型等方面,确保数据库安全性能
    2024-10-10
  • Oracle同步数据到kafka的方法

    Oracle同步数据到kafka的方法

    本文主要介绍如何使用kafka-connect-oracle开源工具,将Oracle dml产生的数据实时同步至kafka,供kafka消费,对Oracle同步数据到kafka的方法感兴趣的朋友一起看看吧
    2022-02-02
  • oracle in长度限制的两个快速解决方法

    oracle in长度限制的两个快速解决方法

    这篇文章主要给大家介绍了关于oracle in长度限制的两个快速解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • Oracle11g调整SGA方法详解

    Oracle11g调整SGA方法详解

    这篇文章主要介绍了Oracle11gSGA调整方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-07-07

最新评论