在SQLPlus上执行脚本时,它会打印一系列数字而不是输出

时间:2014-01-07 12:32:48

标签: oracle sqlplus

我正在尝试在SQL PLus上执行脚本,这很简单。

SET serveroutput ON;
DECLARE
    mode NUMBER(1) := 1;

IF (mode = 1) THEN

    prompt 'HERE'

END IF;

prompt 'fim'

成功连接后,我使用sqlplus user/pw@db@myscript.sql从SQLPlus调用脚本。但输出对我来说很奇怪:

Conectado a:
Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
With the Partitioning, OLAP and Data Mining options

SQL> @myscript.sql
 9
 10
 11

它会继续无限期地打印这个序列。 我做错了什么?

3 个答案:

答案 0 :(得分:7)

从您编辑过的问题...您必须在新行上使用/终止PL / SQL块以使其结束并运行,否则SQL * Plus将继续提示输入更多行代码(这是你看到的数字)。 The documentation shows how to run PL/SQL blocksprompt是一个SQL * Plus命令,因此您无法在PL / SQL块中使用它。您也没有正确的块语法:

SET serveroutput ON;
DECLARE
    mode NUMBER(1) := 1;
BEGIN
    IF mode = 1 THEN
        DBMS_OUTPUT.PUT_LINE('HERE');    
    END IF;
END;
/

prompt fim

答案 1 :(得分:3)

你不能在plsql中使用sqlplus命令。我们可以使用dbms_output而不是在SQL提示符下显示输出

SET serveroutput ON;
DECLARE
mode NUMBER(1) := 1;
BEGIN
IF (mode = 1) THEN
dbms_output.put_line('HERE');
END IF;
dbms_output.put_line('fim');
END;
/

答案 2 :(得分:0)

转到您的oracle主页Oracle\product\<version>\client_2\sqlplus\admin\glogin.sql并添加以下行以启用全局打印,

SET ECHO ON;
SET TERM ON;
WHENEVER SQLERROR EXIT FAILURE ROLLBACK;
SET DEFINE OFF;