【问题标题】:SQL*Plus and SQL DeveloperSQL*Plus 和 SQL Developer
【发布时间】:2015-11-26 12:10:14
【问题描述】:

我有一个关于在 SQL*PLUS 中执行 pl/sql 脚本的简单问题:

create or replace trigger CICD.S_ACCNT_POSTN_DELETE
   after delete on CICD.S_ACCNT_POSTN    
   FOR EACH ROW 
BEGIN
    INSERT INTO CICD.CX_PROCCHLDDEL (ROW_ID, OBJECT_TYPE, PARENT_ID,
          CHILD_ID,STATUS,CREATED,CREATED_BY,LAST_UPD,LAST_UPD_BY)
    VALUES (:old.ROW_ID,'AccountTeam', :old.OU_EXT_ID, :old.POSITION_ID
          ,'Not Synchronized', SYSDATE,:old.CREATED_BY
          ,SYSDATE,:old.LAST_UPD_BY);
END;

此脚本生成以下错误:

E- ORA-00900: invalid SQL statement

E- oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:440)
E- oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:396)
E- oracle.jdbc.driver.T4C8Oall.processError(T4C8Oall.java:837)
E- oracle.jdbc.driver.T4CTTIfun.receive(T4CTTIfun.java:445)
E- oracle.jdbc.driver.T4CTTIfun.doRPC(T4CTTIfun.java:191)
E- oracle.jdbc.driver.T4C8Oall.doOALL(T4C8Oall.java:523)
E- oracle.jdbc.driver.T4CStatement.doOall8(T4CStatement.java:193)
E- oracle.jdbc.driver.T4CStatement.executeForRows(T4CStatement.java:999)
E- oracle.jdbc.driver.OracleStatement.doExecuteWithTimeout(OracleStatement.java:1315)
E- oracle.jdbc.driver.OracleStatement.executeInternal(OracleStatement.java:1890)
E- oracle.jdbc.driver.OracleStatement.execute(OracleStatement.java:1855)
E- oracle.jdbc.driver.OracleStatementWrapper.execute(OracleStatementWrapper.java:304)
E- com.uc4.ara.feature.database.SQLFeature.executeSQLScript(SQLFeature.java:164)
E- com.uc4.ara.feature.database.SQLFeature.run(SQLFeature.java:53)
E- com.uc4.ara.feature.AraFileCmd.main(AraFileCmd.java:120)

我也尝试过在顶部执行带有 DECLARE 的脚本。这样做时,我收到以下错误:

 E- ORA-06550: line 2, column 1:
PLS-00103: Encountered the symbol "CREATE" when expecting one of the following:

   ( begin case declare exit for goto if loop mod null pragma
   raise return select update while with <an identifier>
   <a double-quoted delimited-identifier> <a bind variable> <<
   continue close current delete fetch lock insert open rollback
   savepoint set sql execute commit forall merge pipe purge

E- oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:440)
E- oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:396)
E- oracle.jdbc.driver.T4C8Oall.processError(T4C8Oall.java:837)
E- oracle.jdbc.driver.T4CTTIfun.receive(T4CTTIfun.java:445)
E- oracle.jdbc.driver.T4CTTIfun.doRPC(T4CTTIfun.java:191)
E- oracle.jdbc.driver.T4C8Oall.doOALL(T4C8Oall.java:523)
E- oracle.jdbc.driver.T4CStatement.doOall8(T4CStatement.java:193)
E- oracle.jdbc.driver.T4CStatement.executeForRows(T4CStatement.java:999)
E- oracle.jdbc.driver.OracleStatement.doExecuteWithTimeout(OracleStatement.java:1315)
E- oracle.jdbc.driver.OracleStatement.executeInternal(OracleStatement.java:1890)
E- oracle.jdbc.driver.OracleStatement.execute(OracleStatement.java:1855)
E- oracle.jdbc.driver.OracleStatementWrapper.execute(OracleStatementWrapper.java:304)
E- com.uc4.ara.feature.database.SQLFeature.executeSQLScript(SQLFeature.java:164)
E- com.uc4.ara.feature.database.SQLFeature.run(SQLFeature.java:53)
E- com.uc4.ara.feature.AraFileCmd.main(AraFileCmd.java:120)

有趣的是,当我在 SQL Developer 中粘贴两个脚本中的任何一个时,它都能完美地执行脚本。这让我很困惑。

现在我想知道我是否可以以某种方式将这些脚本转换为可以在 SQL*PLUS 中执行的有效 PL/SQL 脚本,还是有其他方法?

附言运行 Sun Solaris。

SQLPLUS:SQLPlus:版本 11.2.0.2.0

非常感谢。

【问题讨论】:

  • SQL*Plus 不会抛出 Java 错误堆栈。因此,您必须使用其他工具。您是否使用构建工具(Ant?Maven?Hand-rolled Groovy?)运行脚本?
  • 我认为这来自上一个语句,该语句没有以 / 在自己的行中终止。请参阅line 2:您的 CREATE 关键字位于第 1 行。
  • 如果我在顶部使用 BEGIN 会收到第二条错误消息,如果我在顶部使用 DECLARE(这对我来说非常合乎逻辑)而不是 BEGIN,我只会得到 E-ORA-00900:无效的 SQL 语句。此外,如果我什么都不放在那里,我会得到无效的 SQL 语句。是的,我正在运行一个自动化工具来执行这个命令。
  • 谢谢你们的回复。不胜感激。

标签: sql oracle plsql sqlplus plsqldeveloper


【解决方案1】:

“有趣的是,当我在 SQL Developer 中粘贴这两个脚本中的任何一个时,它都能完美地执行脚本。”

您只显示了一个脚本。但是,您发布的那个缺少尾随 /。 SQLPlus 使用斜线表示 PL/SQL 可执行语句的结束。因此,假设这不仅仅是一个发布错误,您在 PL/SQL 语句的末尾有两个没有斜线的脚本。这意味着 SQLPlus 引擎无法将它们分开,这可能会导致 SQL Plus 抛出 ora-00900 异常。

当然,如果您手动运行这些脚本,您会看到 SQL Plus 挂起,等待您输入终止斜杠。我认为 Java 错误堆栈意味着您正在通过某种形式的构建运行器运行脚本。

诸如 SQL Developer 之类的 IDE 将运行一个不带斜杠的单独脚本,因为它们会处理它;通过突出显示一些代码并按 [F8],他们可以找出语句并模拟尾部斜杠。

【讨论】:

  • 也感谢您的回复,我确实在最后放了一个斜杠,并且还尝试在 BEGIN(脚本的第二部分)之前放一个斜杠,这些都不起作用。我需要以某种方式重构代码以使其对 SQL*Plus 有效.....
猜你喜欢
  • 2021-08-09
  • 2012-05-11
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-01-30
  • 1970-01-01
相关资源
最近更新 更多