PLS-00103:遇到符号“;”当期待以下之一时:

Posted

技术标签:

【中文标题】PLS-00103:遇到符号“;”当期待以下之一时:【英文标题】:PLS-00103: Encountered the symbol ";" when expecting one of the following: 【发布时间】:2013-04-30 20:46:11 【问题描述】:

我正在尝试插入用户安全问题的答案,以用于密码重置功能。

Ellucian Banner v8+ 提供了一个 API 来运行它,我对他们的 API 非常陌生,从下面的错误消息的外观来看,我离正确运行它还很远。任何帮助表示赞赏。

我尝试在 Oracle SQL Developer 中运行它:

execute gb_pin_answer.p_create(
    P_PIDM        =>    12345,
    P_NUM         =>    1,
    p_gobqstn_id  =>    1,
    p_qstn_desc   =>    '',
    p_ansr_desc   =>    'David',
    p_ansr_salt   =>    'A123B456',
    p_user_id     =>    'W:H12345678',
    p_data_origin =>    'WWW_USER',
    p_rowid_out         OUT gb_common.internal_record_id_type
);

这是在黑暗中拍摄的,但我想试一试,尝试执行该包的 p_create 函数时会显示错误消息:

从命令的第 15 行开始出错:执行 gb_pin_answer.p_create( 错误报告:ORA-06550: line 1, column 30: PLS-00103: Encountered the 象征 ”;”预期以下情况之一时:

( ) - + case mod new not null table continue avg count 当前存在 max min prior sql stddev sum variance 执行 multiset 两个领先的尾随 forall 合并年月日小时 分 秒 timezone_hour timezone_minute timezone_region timezone_abbr 时间 时间戳 间隔 日期 06550. 00000 - “第 %s 行,第 %s 列:\n%s” *原因:通常是 PL/SQL 编译错误。 *行动:

从命令的第 16 行开始出错:P_PIDM => 12345,错误 报告:未知命令

从命令的第 17 行开始出错:P_NUM => 1,错误报告: 未知命令

从命令的第 18 行开始出错:p_gobqstn_id => 1,错误报告: 未知命令

从命令的第 19 行开始出错:p_qstn_desc => '', Error 报告:未知命令

从命令的第 20 行开始出错:p_ansr_desc => 'David', Error 报告:未知命令

从命令的第 21 行开始出错:p_ansr_salt => 'A123B456', 错误报告:未知命令

从命令的第 22 行开始出错:p_user_id => 'W:H12345678', 错误报告:未知命令

从命令的第 23 行开始出错:p_data_origin => 'WWW_USER', 错误报告:未知命令

从命令中的第 24 行开始出错:p_rowid_out OUT gb_common.internal_record_id_type 错误报告:未知命令

从命令中的第 25 行开始的错误:) 错误报告:未知命令

这是我读到使用这个函数的地方,p_create:http://inb1.banner.ecu.edu:9090/api_erd_index_guide/api/general/gb_pin_answer.html#p_create

更新:出错的代码:

SET SERVEROUTPUT ON
declare
  l_rowid_out gb_common.internal_record_id_type;
BEGIN
  gb_pin_answer.p_create(P_PIDM => 36706, P_NUM => 1, P_GOBQSTN_ID => 1, P_QSTN_DESC => '', P_ANSR_DESC => 'David', P_ANSR_SALT => 'HB123456', P_USER_ID => 'H00036657', P_DATA_ORIGIN => 'WWW_USER', P_ROWID_OUT => 1_rowid_out);
  dbms_output.put_line('rowid: ' || l_rowid_out);
END;

错误信息:

错误报告:ORA-06550:第 4 行,第 199 列:PLS-00363:表达式“1” 不能用作分配目标 ORA-06550:第 4 行,第 3 列: PL/SQL:语句被忽略 06550. 00000 - “第 %s 行,第 %s 列:\n%s” *原因:通常是 PL/SQL 编译错误。 *行动:

【问题讨论】:

【参考方案1】:

问题是execute。这实际上是一个简短的匿名 PL/SQL 块的简写,不能跨行拆分。 (除了可能有一个延续字符,但如果我曾经有过这样的工作,我就记不起来了)。只有第一行被翻译,所以它正在有效地尝试运行:

begin execute gb_pin_answer.p_create(; end;
/

... 它非常合理地不喜欢以p_create(; 结尾的命令。然后将过程调用的其余部分视为 10 个单独的命令,这些命令会生成您遇到的其他错误,并且它们在这种情况下也是合理的。

解决方案是将整个过程调用放在一行中,这会使其更难阅读;或者干脆使用你自己的块,而不是依赖execute

begin
    gb_pin_answer.p_create(
        ...
    );
end;
/

最后一个参数不对;来自OUT ... 的位需要替换为=> some_value,就像你对其他人所做的那样。但它是一个输出参数,所以你需要一些东西来输入值。没有看到你正在运行的脚本中还有什么,我无法判断你是否已经处理过它,但是使用这种模式你可以可能只是在匿名块中添加一个变量:

set serveroutput on
declare
    l_rowid_out gb_common.internal_record_id_type;
begin
    gb_pin_answer.p_create(
        ...
        p_rowid_out => l_rowid_out
    );
    -- optional
    dbms_output.put_line('rowid: ' || l_rowid_out);
end;
/

【讨论】:

我试过了: SET SERVEROUTPUT ON declare l_rowid_out gb_common.internal_record_id_type; BEGIN gb_pin_answer.p_create(P_PIDM => 36706, P_NUM => 1, P_GOBQSTN_ID => 1, P_QSTN_DESC => '', P_ANSR_DESC => 'David', P_ANSR_SALT => 'HB123456', P_USER_ID => 'H00036657', P_DATA_ORIGIN => 'WWW_USER', P_ROWID_OUT => 1_rowid_out); dbms_output.put_line('rowid: ' || l_rowid_out);结尾; / 它返回的错误消息片段:错误报告:ORA-06550:第 4 行,第 215 列:PLS-00103:在预期以下情况之一时遇到符号“”:)、* & = - + at in is mod 余数 not rem or != or ~= >= and or like like2 like4 likec || multiset member submultiset 在 "" 之前插入符号 ", 以继续。06550. 00000 - "line %s, column %s:\n%s" *原因:通常是 PL/SQL 编译错误。*操作: @Brad - 你真的有 1_rowid_out 而不是 l_rowid_out 作为参数吗? 是的,我不确定需要传递什么值。我是这些包的新手。 @Brad 如果你用反引号包围代码和错误部分,你的 cmets 会更容易阅读,顺便说一句......尽管它们对于 cmets 来说真的太长了......我会看看是否我可以重现那个。但是1_rowid_out 是错误的,它必须与您声明的变量匹配。如果错误报告实际上是... the symbol "_" when ...,那就是问题所在;只需将1_ 更改为l_【参考方案2】:

从上次编辑中,我发现您将 1 误认为是 l... 1_rowid_out 而不是 l_rowid_out

您不能像您尝试的那样以数字开头。

【讨论】:

【参考方案3】:

我们在混合 Dapper 和原生 Oracle MDA 结构时遇到了这个错误。特别尝试将 WithConnection 构造与本机 Oracle 驱动程序一起使用。它不喜欢这样,并返回了一个非常相似且无意义的错误消息“ORA-06550:第 1 行,第 259 列:PLS-00103:遇到符号...等等等等”

【讨论】:

以上是关于PLS-00103:遇到符号“;”当期待以下之一时:的主要内容,如果未能解决你的问题,请参考以下文章

PLS-00103:在期待以下之一时遇到符号“&”:%符号“%被插入在“&”之前继续[关闭]

PLS-00103:预期时遇到符号“(”

PLS-00103 遇到符号“数字”

PLS-00103:在预期以下情况之一时遇到符号“TEST_PKG”:;

错误:PLS-00103:遇到符号“;”当期望以下之一时:* & = - + < / > at in is mod remaining not rem then

错误:PLS-00103:在预期以下情况之一时遇到符号“)”