首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >通过批处理文件将参数传递给SQL查询不起作用

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

Stack Overflow用户
提问于 2015-04-02 11:35:59
回答 1查看 1.4K关注 0票数 0

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

SQL

代码语言:javascript
复制
    Select empSal from Emp_Master where empID = '&2';
    exit

批处理文件

代码语言:javascript
复制
sqlplus -s myusername/mypass@%1 @E:\fetchEmpSal.sql %2 > E:\fetchEmpSal_log.txt

%1 -将是我的db名称或实例名称。%2 -将是我的empId。

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

代码语言:javascript
复制
fetchEmpSal.bat mydb 1011

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

编辑:

现在,当我使用上面的方法调用批处理文件时,命令更改如下。

代码语言:javascript
复制
sqlplus -s myusername/mypass@mydb @E:\fetchEmpSal.sql 1011  > E:\fetchEmpSal_log.txt

但是,没有将1011作为参数传递到SQL中。这是它过去的工作方式,但我不知道它为什么不起作用。任何帮助都将不胜感激。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-04-03 11:56:06

也许我在这里遗漏了一些东西,但您就不能将SQL更改为下面的内容吗?

代码语言:javascript
复制
Select empSal from Emp_Master where empID = '&1';    -- not &2
exit

您只为您的SQL*Plus脚本提供了一个参数值,因此,SQL*Plus很难为&2找到一个值,这也许并不奇怪。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29411977

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档