首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL*Plus和SQL Developer

SQL*Plus和SQL Developer
EN

Stack Overflow用户
提问于 2015-09-01 09:49:33
回答 1查看 1.1K关注 0票数 2

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

代码语言:javascript
复制
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;

此脚本将生成以下错误:

代码语言:javascript
复制
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)

我也尝试过在顶部执行声明脚本。在执行此操作时,我会得到以下错误:

代码语言:javascript
复制
 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)

有趣的是,当我将这两个脚本中的任何一个粘贴到中时,它会非常好地执行脚本。这就是让我困惑的地方。

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

附注:运行Sun Solaris。

SQL_PLUS: SQL_Plus: 11.2.0.2.0版

非常感谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-09-02 06:47:46

“有趣的是,当我在中粘贴这两个脚本之一时,它执行的脚本非常好。”

你只展示了一个脚本。然而,你发布的那篇文章没有一个落后的/。SQL_Plus使用斜杠来指示PL/SQL可执行语句的结尾。因此,假设这不仅仅是一个投递错误,那么在PL/SQL语句末尾有两个没有斜杠的脚本。这意味着SQL_Plus引擎无法将它们分开,这可能导致SQL_Plus抛出一个ora-00900异常。

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

IDE(如statement )将运行一个没有尾随斜杠的单独脚本,因为它们处理它;通过突出显示一些代码并按下F8,他们可以找到语句并模拟尾随斜杠。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32328511

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档