通过批处理文件将参数传递给 SQL 查询不起作用
Passing Parameters to SQL Query through Batch file doesn't work
我有一个简单的 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 - 将是我的 empId。
这就是我调用批处理文件的方式。我打开 CMD,导航到路径并输入以下内容。
fetchEmpSal.bat mydb 1011
现在,批处理文件运行正常,但每次它都要求输入 empID。这是通过批处理文件将参数传递给 sql 的正确方法吗?请帮助
编辑:
现在,当我使用上述方法调用批处理文件时,命令如下所示。
sqlplus -s myusername/mypass@mydb @E:\fetchEmpSal.sql 1011 > E:\fetchEmpSal_log.txt
但是,1011 没有作为参数传递给 SQL。这是它以前的工作方式,但我不知道为什么它不工作。任何帮助,将不胜感激。
也许我在这里遗漏了一些东西,但是你不能把你的 SQL 改成下面的吗?
Select empSal from Emp_Master where empID = '&1'; -- not &2
exit
您只为 SQL*Plus 脚本提供了一个参数值,因此 SQL*Plus 很难为 &2
找到一个值也许并不奇怪.
我有一个简单的 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 - 将是我的 empId。
这就是我调用批处理文件的方式。我打开 CMD,导航到路径并输入以下内容。
fetchEmpSal.bat mydb 1011
现在,批处理文件运行正常,但每次它都要求输入 empID。这是通过批处理文件将参数传递给 sql 的正确方法吗?请帮助
编辑:
现在,当我使用上述方法调用批处理文件时,命令如下所示。
sqlplus -s myusername/mypass@mydb @E:\fetchEmpSal.sql 1011 > E:\fetchEmpSal_log.txt
但是,1011 没有作为参数传递给 SQL。这是它以前的工作方式,但我不知道为什么它不工作。任何帮助,将不胜感激。
也许我在这里遗漏了一些东西,但是你不能把你的 SQL 改成下面的吗?
Select empSal from Emp_Master where empID = '&1'; -- not &2
exit
您只为 SQL*Plus 脚本提供了一个参数值,因此 SQL*Plus 很难为 &2
找到一个值也许并不奇怪.