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

Posted

技术标签:

【中文标题】在 SQLPlus 上执行脚本时,它会打印一系列数字而不是输出【英文标题】:When executing a script on SQLPlus, it prints a sequence of numbers instead of output 【发布时间】:2014-01-07 12:32:48 【问题描述】:

我正在尝试在 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

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

【问题讨论】:

肯定会打印出here,除非脚本中有其他内容。 你的 script.sql 中有什么? 它打印代码的行号,当你按回车时它可能会打印它。这种行为的原因可能是您的myscript.sql 文件包含未被/ PL/SQL 块终止。 我不认为你正在执行你认为的脚本。 (它看起来确实包含一个没有终止的 PL/SQL 块)。它是否在您启动 SQL*Plus 的同一目录中?你有SQLPATH set in your environment吗? 直到你给出'/',你的脚本内容作为 PL/SQL 块将永远不会发送到 oracle,它会等待显示从你脚本的最后一行开始的数字,因为你一直按 Enter! 【参考方案1】:

根据您编辑的问题...您必须在新行上使用 / 终止 PL/SQL 块以使其结束并运行,否则 SQL*Plus 将继续提示输入更多代码行(即你看到的数字)。 The documentation shows how to run PL/SQL blocks。 prompt 是一个 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

【讨论】:

@DiogoMoreira - 请阅读文档以确保您了解它为什么现在有效,以及为什么您的版本无效。除了 SQL*Plus 指南,您还应该查看PL/SQL language reference。【参考方案2】:

您不能在 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;
/

【讨论】:

【参考方案3】:

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

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

【讨论】:

我认为这不能解决实际问题;您的答案将显示正在执行的内容,但原始帖子的 cmets 会回答问题。

以上是关于在 SQLPlus 上执行脚本时,它会打印一系列数字而不是输出的主要内容,如果未能解决你的问题,请参考以下文章

SQLPLUS 不打印受影响的行数

sqlplus中设置在屏幕中上不打印出输出

使用 sqlplus 打印错误

在 sqlplus 中执行脚本时出错,选项不是有效数字

如何在shell中调SQLPLUS 执行SQL语句

在 sqlplus 程序中打印调试消息