快速解决 Error 45 initializing SQL*Plus 错误

来源:互联网 发布:datagridview清除数据 编辑:程序博客网 时间:2024/05/20 07:31

最近,经常碰到使用sqlplus在后台运行sql脚本的情况,于是就遭遇了 Error 45 initializing SQL*Plus错误.

 

我运行的PL/SQL 文件 test.sql 如下

set serveroutput on;set timing on;DECLAREBEGIN  dbms_output.put_line(TO_CHAR(SYSDATE,'YYYY-MM-DD HH24:MI:SS'));END;

该SQL文件所运行的Home folder所在磁盘的文件系统为 ext4. 关于文件类型,可以通过查看 /etc/fstab 文件确认.


后台运行sql 文件的命令如下

nohup sqlplus iqm_blk/welcome1@IQMDEV @test.sql > test.out 2>&1 &


我这里总结一下错误的主要原因

  •   test.sql 文件END;后不能有空行
  •   test.sql文件END;后,需要加入 /
  •   需要在/后加入exit; 命令. 当加入了exit; 后, 空行是没问题的.

能正确执行的脚本如下

set serveroutput on;set timing on;DECLAREBEGIN  dbms_output.put_line(TO_CHAR(SYSDATE,'YYYY-MM-DD HH24:MI:SS'));END;/exit;

希望对大家有帮助。

0 0
原创粉丝点击