- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
为了练习 PL/SQL,我根据 ORACLE 文档编写了这个简单的过程:
create procedure BADGE_PROCEDURE (badges NUMBER) AS
loops NUMBER;
BEGIN
loops := badges;
loops := loops - 1;
BEGIN LOOP
insert into BADGE values (BADGE_ID_SEQUENCE.nextval, 'prova', 'prova', '01-JAN-01');
loops := loops - 1;
EXIT WHEN loops < 0;
END LOOP;
END;
/
这是我的 BADGE 表:
CREATE TABLE BADGE
(badge_id NUMBER PRIMARY KEY,
name VARCHAR(20),
surname VARCHAR(20) NOT NULL,
birthday DATE);
最后这是我的顺序:
CREATE SEQUENCE BADGE_ID_SEQUENCE
start with 1
increment by 1
nocache
nocycle;
但是,程序编译时出现以下错误:
LINE/COL ERROR
-------- -----------------------------------------------------------------
11/5 PLS-00103: Encountered the symbol "end-of-file" when expecting
one of the following:
( begin case declare end exception 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
我做错了什么?
最佳答案
syntax for a loop是 LOOP ... END LOOP;
没有 BEGIN
。
create procedure BADGE_PROCEDURE (badges NUMBER) AS
loops NUMBER;
BEGIN
loops := badges;
loops := loops - 1;
LOOP
insert into BADGE values (BADGE_ID_SEQUENCE.nextval, 'prova', 'prova', DATE '2001-01-01');
loops := loops - 1;
EXIT WHEN loops < 0;
END LOOP;
END;
/
然而,一个更简单的版本是:
create procedure BADGE_PROCEDURE (badges NUMBER) AS
BEGIN
FOR loops IN 1 .. badges LOOP
insert into BADGE values (BADGE_ID_SEQUENCE.nextval, 'prova', 'prova', DATE '2001-01-01');
END LOOP;
END;
/
关于sql - ORACLE - 过程中出现错误 PLS-00103,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37681604/
我有一个 Oracle 数据库 12c Release 12.1.0.1.0 - 64 位生产数据库。我正在尝试通过公共(public) dblink (DEVICE_201) 在 Oracle Da
我正在使用 R 中的 plspm 包对信息安全的风险评估进行建模。但是,当我运行分析时,出现以下错误: Error in if (w_dif < specs$tol || iter == specs$
我正在制作一个使用流式传输的类似 radio 的应用程序。在这里,我需要从链接 (http://somedomain/some.pls) 流式传输音频。 我已经创建了 MediaPlayer 并且知道
我正在尝试创建这个函数: create or replace function g(sN int) return char(3) as t char(3); begin s
以下是我的oracle版本 Oracle 数据库 11g 企业版 11.2.0.2.0 版 - 64 位生产 我试图改变一个表来添加一列,但由于它花了很长时间,我取消了它。 一段时间后,我开始在所有引
我执行了创建下表的 PL/SQL 脚本 TABLE_NAME VARCHAR2(30) := 'B2BOWNER.SSC_Page_Map'; 我使用参数为这个表创建了一个插入函数 CREATE OR
我想将Rownum存储为变量,而不是使用昂贵的Join。 我需要从Select语句中获取此信息,因为Rownum在各种环境下都会有所不同,因此它不能是代码中的文字字符串。 对于上下文,此查询在Orac
刚刚完成编写将错误记录到表中的错误日志过程。我刚完成我的第一个异常处理程序,由于此错误,我无法编译该程序包。 我相信我在调用write_error_log过程时遇到此错误。 以下是包装中的代码。 CR
Closed. This question does not meet Stack Overflow guidelines。它当前不接受答案。 想改善这个问题吗?更新问题,以便将其作为on-topic
尝试编译时出现以下错误 Error(16,8): PLS-00103: Encountered the symbol "SPROLLUPEXPENSEITEM" when expecting one
我在调用我的程序时遇到问题。甲骨文紧急暂停 PLS-00306 Error: Wrong number of types of arguments in call to procedure. 我的类型
收到与函数相关的以下错误: 'ERROR at line 20: PLS-00103: Encountered the symbol "end-of-file" when expecting one
我需要一些关于如何在我的jsp中使用jquery ajax的帮助,网上有很多例子,但它是基于php的,有些不涉及sql。 我的 jsp 中有 2 个选择框 Category
我创建了一个带有单选按钮的 CSS 图像 slider 来控制它。我已将单选按钮设置为 visibility: hidden并使用缩略图作为标签。 html 看起来像这样: 对其他缩略图重复
我想从网站播放 PLS 文件 ( http://live.radioguerrilla.ro:8002/listen.pls )。我想使用 HTML5 引入的 audio 标签,但我认为它不能从 PL
前几天编写一个存储过程,需要访问远程数据库的字段,于是建立一个dbLink并建了同义词: ?
我正在包中创建一个过程。我已经更新了包的规范,然后当我更新包的主体时,它向我显示以下错误。 [Error] PLS-00323 (314: 13): PLS-00323: subprogram or
请帮助我理解这个错误..可能是我必须执行 ud_mosh_dvig(x number, y number) 并在之后创建类型主体。 create or replace type CAR as obje
这个包有什么问题,因为它给出了错误? CREATE OR REPLACE PACKAGE PKG_SHOW_CUST_DETAILS AS PROCEDURE SHOW_CUST_DETAIL
在创建具有重载函数的包时,请帮助查找错误。 显示错误: PL-00103:在期待以下之一时遇到符号“NUMOU”:语言。 PL-00103:在预期以下情况之一时遇到符号“函数”:结束而不是编译指示最终
我是一名优秀的程序员,十分优秀!