通过批处理文件将参数传递给SQL查询并不起作用

时间:2015-04-02 11:36:00

标签: sql oracle batch-file sqlplus

我有一个简单的SQL查询,我使用批处理文件执行。我通过提供参数来调用批处理文件。

SQL

    Select empSal from Emp_Master where empID = '&2';
    exit

批处理文件

sqlplus -s myusername/mypass@%1 @E:\fetchEmpSal.sql %2 > E:\fetchEmpSal_log.txt

%1 - 将是我的数据库名称或实例名称。 %2 - 将是我的用武之地。

这是我调用批处理文件的方法。我打开CMD,导航到路径并输入以下内容。

fetchEmpSal.bat mydb 1011

现在,批处理文件运行正常,但每次都要求提供empID。这是通过批处理文件将参数传递给sql的正确方法吗?请帮忙

编辑:

现在,当我使用上述方法调用批处理文件时,命令会发生如下变化。

sqlplus -s myusername/mypass@mydb @E:\fetchEmpSal.sql 1011  > E:\fetchEmpSal_log.txt

但是,1011不会作为参数传递给SQL。这是它以前的工作方式,但我不知道它为什么不起作用。任何帮助,将不胜感激。

1 个答案:

答案 0 :(得分:0)

也许我在这里遗漏了一些东西,但你不能只将SQL更改为以下内容吗?

Select empSal from Emp_Master where empID = '&1';    -- not &2
exit

您只为SQL * Plus脚本提供了一个参数值,因此SQL * Plus很难找到&2的值。