当前位置:  数据库>oracle

使用PL/SQL执行OS命令

    来源: 互联网  发布时间:2017-05-24

    本文导语: pl/sql做为sql语言的一种补充语言,其优势自然是在处理数据方面,但是随着PL/SQL的不断成长,尤其是和JAVA语言的联系越来越紧密,这使得PL/SQL也能完成一些高级应用操作了。 之前也有介绍使用PL/SQL执行java存储来获得MAC地址的 这里方...

pl/sql做为sql语言的一种补充语言,其优势自然是在处理数据方面,但是随着PL/SQL的不断成长,尤其是和JAVA语言的联系越来越紧密,这使得PL/SQL也能完成一些高级应用操作了。

之前也有介绍使用PL/SQL执行java存储来获得MAC地址的

这里方法也类似,只是需要传入命令参数.

同样首先创建java source

create or replace and compile java source named ExeSysCommand as
import java.io.*;
public class ExeSysCommand
{
  public static String ExeCmd(String args) {
        Runtime run = Runtime.getRuntime();
        Process process = null;
        try {
            process = run.exec(args); // 执行cmd命令
            return "OK!";
        } catch (Exception e) {
            return e.getMessage();
        }
        }
  public static void main(String[] args)
  {
    System.out.println("No command line arguments");
  }
}

其后创建函数调用该java soure

CREATE OR REPLACE FUNCTION ExeCmd(cmd STRING) RETURN VARCHAR2 IS --执行OS命令测试
  LANGUAGE JAVA NAME ' ExeSysCommand.ExeCmd(java.lang.String) return java.lang.String';

注意:有参数cmd,对应java的输入类型应当为java.lang.String.

还应当注意的是这些应当在SYS用户下操作,如果在其他用户下,会获得错误:

the Permission (java.io.FilePermission execute) has not been granted to SCOTT. The PL/SQL to grant this is dbms_java.grant_permission( 'SCOTT', 'SYS:java.io.FilePermission', '', 'execute' )

如果确实需要其他用户来执行,可以使用dbms_java.grant_permission来给相应用户赋权限.

下面是在windows环境下操作:

C:Documents and SettingsAdministrator>tasklist | find "calc"

先确认系统当前没有运行计算器程序.

好,让我们来用刚建立的plsql函数execmd来运行这个计算器程序.

C:Documents and SettingsAdministrator>sqlplus / as sysdba

SQL*Plus: Release 11.2.0.1.0 Production on 星期三 7月 10 17:26:17 2013

Copyright (c) 1982, 2010, Oracle.  All rights reserved.


连接到:
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

17:26:17 SYS@orcl> select execmd('calc') from dual;

EXECMD('CALC')
-----------------------------------------------------------------------------------------

OK!

已用时间:  00: 00: 00.06
17:26:37 SYS@orcl> host
Microsoft Windows XP [版本 5.1.2600]
(C) 版权所有 1985-2001 Microsoft Corp.

C:Documents and SettingsAdministrator>tasklist | find "calc"
calc.exe                  12000 Console                0      3,052 K

好了,我们看到计算器程序已经在运行了,但是非常不如意的是,没有界面出来。。。

我猜想可能是由于Oracle最早是基于linux开发,而且和MS是死对头(相关信息请查询Oracle的发家史...),所以没有考虑过支持WIN界面.

--

不过就算这样,也很方便了,我们可以建立定时JOB,通过PL/SQL来调用OS上的任何程序/脚本等做相关的任务了.


    
 
 

您可能感兴趣的文章:

  • c/c++预处理命令预#,##使用介绍
  • 使用ps命令,如何使用系统命令根据进程名称获取进程和子进程的ID?除了ps,还有其它系统命令的办法吗?谢谢。
  • linux下free命令显示的内存使用情况分析
  • 在Linux下使用ftp命令,被提示命令没有找到
  • linux下不使用sudo命令执行docker的操作步骤
  • 怎样在命令行使用ftp命令?
  • linux下objdump命令用法介绍及如何使用objdump命令进行反汇编
  • linux命令行下使用curl命令查看自己机器的外网ip
  • linux/Centos/ubuntu下如何使用umask命令修改新建文件时的默认权限
  • tar命令的-r和--delete子命令该如何使用啊?
  • linux下top命令详解包括top命令参数使用及结果(virt,res,shr)排序举例说明
  • 在LINUX中使用C调用系统命令,怎么取得系统命令的输出?
  • linux top命令详解以及top命令的各项使用技巧详细说明
  • 在windows的命令提示符下使用linux的命令,听说安装一个软件即可?在线等。立刻给分
  • mongoDB 2.6.5下载,安装及mongoDB基本使用命令介绍
  • 请教:使用system(命令)或者exec(命令)启动一个进程执行命令,如何判断这个命令是否启动成功或正在运行?
  • mongoDB 3.2.9 官方下载、安装及mongoDB基本使用命令详细介绍
  • 性能测试中应该用top命令统计cpu使用情况还是ps命令?
  • ftp协议介绍及ftp常用的上传下载等操作命令使用方法
  • 请问在unix下,如何察看以前使用者的使用命令
  • mongodb 数据库常用命令使用实例
  • 我初学NETTERM的使用,在哪里可以找到所有(或常用的)命令的使用方法呢?还是需要在什么书上可以找到?
  • 在测试memset函数的执行效率时,分为使用Cash和不使用Cash辆种方式,该如何控制是否使用缓存?
  • SUSE10下,如何使用perl语言执行一条语句:从一台机器telnet到远端另一台机器,在远端机器上执行命令,并能获取到执行结果。请高手指点,Very 谢谢~
  • 关于在QT环境下加载gif图片的问题(可以显示,但是只有使用终端启动可执行文件才能显示,双击执行却不显示)这是为什么?
  • 如何使用crontab来定时执行一个.php的程序
  • 使用Statement.java里的execute执行存储过程问题
  • 关于如何使用shell自动执行一个sybase的存储过程
  • 使用终端远程执行程序的问题!
  • 使用java执行定时任务示例
  • 为什么socket程序使用gdb调试执行就接受不到数据了呢?
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • mysql的SQL_NO_CACHE(在查询时不使用缓存)和sql_cache用法
  • C#使用带like的sql语句时防sql注入的方法
  • 在SQL Server中使用SQL语句查询一个存储过程被其它所有的存储过程引用的存储过程名
  • SQL Server SQL Agent服务使用教程小结
  • 在使用中,经常出现提示为:java.sql.SQLException: [Microsoft][ODBC SQL Server Driver]连接占线导致另一个 hstmt,是什么意思,怎样解
  • SQL Server设置主键自增长列(使用sql语句实现)
  • sql server对索引的使用
  • 使用php语句将数据库*.sql文件导入数据库
  • SQL高级应用之使用SQL查询Excel表格数据的方法
  • sql server 使用ntile获取数据的例子
  • HBase上使用SQL查询 Phoniex
  • 如何使用SQL分页?
  • Oracle SQL使用时注意自己的输入
  • sql server中使用Unicode字符时要注意的问题
  • SQL Server 2008无日志文件如何使用MDF文件附加数据库
  • 大虾帮忙,怎样用JDBC-ODBC连接SQL2000并使用呀?
  • Oracle中SQL语句连接字符串的符号使用介绍
  • SQL SERVER使用REPLACE将某一列字段中的某个值替换为其他的值
  • MS SQL Server游标(CURSOR)的学习使用
  • sql 游标使用笔记
  • sql使用cast进行数据类型转换示例
  • C++ I/O 成员 tellg():使用输入流读取流指针
  • 求ibm6000的中文使用手册 !从来没用过服务器,现在急需使用它,不知如何使用! 急!!!!!
  • C++ I/O 成员 tellp():使用输出流读取流指针
  • 请问:在使用oracle数据库作开发时,是使用pro*c作开发好些,还是使用库函数如oci等好一些啊?或者它们有什么区别或者优缺点啊?
  • Python不使用print而直接输出二进制字符串
  • 急求结果!!假设一个有两个元素的信号量集S,表示了一个磁带驱动器系统,其中进程1使用磁带机A,进程2同时使用磁带机A和B,进程3使用磁带机B。
  • Office 2010 Module模式下使用VBA Addressof
  • c#中SAPI使用总结——SpVoice的使用方法
  • windows下tinyxml.dll下载安装使用(c++解析XML库)
  • 使用了QWidget的程序,如何使用后台程序启动它?


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,