使用 Window 脚本宿主自动化 Oracle 工具

发表于:2007-06-22来源:作者:点击数: 标签:
随着新版Windows 操作系统的发布,命令提示符距离用户越来越遥远了。但是 Oracle 所附带的多数主要 服务器 工具依然是基于命令行的程序,所以完成简单的任务变得俞发困难了。 然而,新版的 Windows 提供一个叫做 Windows 脚本宿主的工具,该工具可以通过执行

   
  随着新版Windows 操作系统的发布,命令提示符距离用户越来越遥远了。但是 Oracle 所附带的多数主要服务器工具依然是基于命令行的程序,所以完成简单的任务变得俞发困难了。
   

  然而,新版的 Windows 提供一个叫做 Windows 脚本宿主的工具,该工具可以通过执行脚本(JScript 或者 Visual Basic Script)来自动化这些任务。一些其它的数据库环境依赖这些脚本完成很多在 Windows 环境下 Oracle 用户不能完成的任务。
  
  有很多资源教我们使用 Windows 脚本宿主的方法。在本文中我将局限于一个特定的例子:自动化 Oracle 导入(import)工具从而能够导入多个文件并提供命令行的语法。
  
  为了执行导入程序,我需要创建一个名为“WScript.Shell”的 COM 对象。对于执行脚本所需要的每个命令行参数,我简单地使用给定的参数构造出命令行并使用 WScript.Shell 的 Run方法来执行。
  
  ' VBScript (dropper.vbs)
  Set WshShell = WScript.CreateObject("WScript.Shell")
  For Each arg in WScript.Arguments
    ' Note "imp" needs single quotes around filenames with spaces
    CmdString = "imp userid=scott/tiger file='" & arg & "' rows=y ignore=y"
    ReturnCode = WshShell.Run(CmdString,1,True)
  Next
  
  // Jscript (dropper.js)
  var WshShell = WScript.CreateObject("Wscript.Shell");
  for (i=0;i  {
    // Note "imp" needs single quotes around filenames with spaces
    var arg = WScript.Arguments.Item(i);
    var CmdString = "imp userid=scott/tiger file='" + arg + "' rows=y
   ignore=y";
    var ReturnCode = WshShell.Run(CmdString,1,true);
  }
  
  虽然这段脚本外表看起来只是简单地改进功能——即在没有输入用户名、口令或者命令行参数的情况下列出多个文件——但其实提供了更多的功能。在 Windows 中,当你选择一个对象并将其拖放到一些可执行程序(像 VBScript 或者 JScript)之上时,文件就会以命令行参数所选择的文件名执行。因此你可以选择一个 Oracle 导出文件然后使用鼠标将其拖入到脚本上,脚本就会自动地对这些文件运行“imp”。也就是说脚本可以允当一个支持拖放的能够装数据导入到数据库的小程序。这样对于那些习惯于 Windows 环境多过命令提示符的用户来说这个方式要友好地多。
  
  你还可以把这个脚本扩展,比如说检查文件的扩展名,对于“.dmp”文件执行“imp”,而对于“.sql”文件使用相同的用户账号执行“sqlplus”。你可能还想要编写脚本访问数据库来自动地将文件装载到 Blob 或者 XML 库,或者为了保密隐藏用户名和口令。最后,你可以修改 Run命令来隐藏控制台窗口,防止其在运行的时候跳出,或者说并行地运行导入(import)而不是每次导入一个文件。
  
  --------------------------------------------------------------------------------
  本文作者:Scott Stephens已经在Oracle工作了13年有余,他曾经在技术支持、电子商务、市场和软件开发等部门工作。
  --------------------------------------------------------------------------------

原文转自:http://www.ltesting.net