我只有一个关于在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脚本,还是有其他方式?
P.S。运行Sun Solaris。
SQL PLUS:SQL Plus:版本11.2.0.2.0
非常感谢。
答案 0 :(得分:0)
&#34;有趣的是,当我在SQL Developer中粘贴两个脚本中的任何一个时,它完全可以执行脚本。&#34;
您只显示了一个脚本。但是,您发布的那个缺少尾随/
。 SQL Plus使用斜杠表示PL / SQL可执行语句的结束。因此,假设这不仅仅是一个发布错误,那么在PL / SQL语句的末尾有两个没有斜杠的脚本。这意味着SQL Plus引擎无法将它们分开,这可能导致SQL Plus抛出ora-00900
异常。
当然,如果您手动运行这些脚本,您会看到SQL Plus挂起,等待您键入终止斜杠。我认为Java错误堆栈意味着您通过某种形式的构建运行程序运行脚本。
SQL Developer等IDE会运行一个没有尾部斜杠的单独脚本,因为它们会处理它;通过突出显示一些代码并按[F8],他们可以找出语句并模拟尾部斜杠。