我正在运行一个简单的批处理文件来执行SQL语句。
批处理文件:
cd /D C:\sqlcl\bin
sql username/password@host:port:SID @C:\scripts\statement.sql
exit
SQL语句运行完美。它将查询结果假脱机到CSV文件中,并返回到SQL>
提示符。
问题是批处理文件没有转到下一行以退出SQL和CMD窗口。不管我测试什么命令,批处理文件都不会转到第三行。
是否需要添加一些内容到*.sql
文件中以使其结束?使用出口我会丢失什么吗?我试过QUIT
,HOST
返回CMD,ECHO
打印某些内容,但与命令无关,它从不执行到该行,但确实返回到SQL提示符。>
答案 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文件,但“退出”不存在。我添加了它,批处理文件现在可以正常工作了。
我不知道为什么会发生此问题。