SQL语句完成后,批处理文件停止,并且不会继续退出

时间:2019-04-19 20:04:40

标签: batch-file cmd sqlcl

我正在运行一个简单的批处理文件来执行SQL语句。

批处理文件:

cd /D C:\sqlcl\bin

sql username/password@host:port:SID @C:\scripts\statement.sql

exit

SQL语句运行完美。它将查询结果假脱机到CSV文件中,并返回到SQL>提示符。

问题是批处理文件没有转到下一行以退出SQL和CMD窗口。不管我测试什么命令,批处理文件都不会转到第三行。

是否需要添加一些内容到*.sql文件中以使其结束?使用出口我会丢失什么吗?我试过QUITHOST返回CMD,ECHO打印某些内容,但与命令无关,它从不执行到该行,但确实返回到SQL提示符。

2 个答案:

答案 0 :(得分:1)

调整您的.sql文件,以在此末尾添加退出。

set feedback off
set head off
set sqlformat csv
spool emp.csv
select * from emp;
exit

照常运行

$ sql klrice/klrice @spool

结果文件是预期的csv。

$ more emp.csv
7369,"SMITH","CLERK",7902,17-DEC-80,800,,20,5555555555554444
7499,"ALLEN","SALESMAN",7698,20-FEB-81,1600,300,30,4929043445510803
7521,"WARD","SALESMAN",7698,22-FEB-81,1250,500,30,6011823599867990
7566,"JONES","MANAGER",7839,02-APR-81,2975,,20,375055626849864
7654,"MARTIN","SALESMAN",7698,28-SEP-81,1250,1400,30,4929727676353442
7698,"BLAKE","MANAGER",7839,01-MAY-81,2850,,30,5262511577814781
7782,"CLARK","MANAGER",7839,09-JUN-81,2450,,10,6011983140249807
7788,"SCOTT","ANALYST",7566,09-DEC-82,3000,,20,343764091280047
7839,"KING","PRESIDENT",,17-NOV-81,5000,,10,5186144047197497
7844,"TURNER","SALESMAN",7698,08-SEP-81,1500,0,30,6011331487563093
7876,"ADAMS","CLERK",7788,12-JAN-83,1100,,20,378775397941460
7900,"JAMES","CLERK",7698,03-DEC-81,950,,30,4916225758678451
7902,"FORD","ANALYST",7566,03-DEC-81,3000,,20,378355660338882
7934,"MILLER","CLERK",7782,23-JAN-82,1300,,10,34567
$ 

答案 1 :(得分:0)

一个有趣的问题导致了这个问题。

在我从SQL Developer导出的原始SQL文件中,最后没有包含“退出”。我在记事本中打开它并添加了“退出”。每次我查看SQL文件时,都在记事本中打开它,然后在其中“退出”。

我刚刚在Notepad +中打开了SQL文件,但“退出”不存在。我添加了它,批处理文件现在可以正常工作了。

我不知道为什么会发生此问题。