• 主页
  • Oracle 基础和管理
  • Oracle 高级技术
  • Oracle 认证与考试
dabaishu730 2012年07月09日
ORACLE存储过程执行错误

create or replace
PROCEDURE DIM_TIME_PROC(
start_date IN VARCHAR2,
end_date IN VARCHAR2
)
AS
--定义变量
begin_time DATE; --开始时间
end_time DATE; --结束时间
dim_date DATE; --中间变量
--i NUMBER; --计数器
date_flag NUMBER; --会计区间值 本例取15 天
--vs_msg VARCHAR2(4000); --错误信息变量
--fmon_type VARCHAR2(20); --财务月类型
BEGIN
--fmon_type = FMONTH_TYPE;
begin_time := to_date(start_date,'yyyymmdd');
end_time := to_date(end_date,'yyyymmdd');
date_flag := to_number(end_time - begin_time);
IF date_flag < 0 THEN
BEGIN
dbms_output.put_line('输入有误,结束日期必须大于开始日期,请重新输入');
END;

ELSE
BEGIN
dim_date := begin_time;
while end_time >= begin_time
LOOP
BEGIN
INSERT INTO dim_time(
DAYKEY )
VALUES(
to_char(dim_date,'yyyymmdd'));
dim_date := dim_date + 1;
END;
end loop;
END;
END IF;
END DIM_TIME_PROC;


错误:


ORA-06550: 第 1 行, 第 7 列:
PLS-00103: 出现符号 "PROCEDURE"在需要下列之一时:
( 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
符号 "PROCEDURE" 被忽略。
06550. 00000 - "line %s, column %s:\n%s"
*Cause: Usually a PL/SQL compilation error.
编译没有错 执行的时候出错,可能是逻辑上有问题吧,小弟菜鸟级别的...请各位高手指点.
...全文
355 点赞 收藏 5
写回复
5 条回复

还没有回复,快来抢沙发~

发动态
发帖子
Oracle
创建于2007-09-28

6391

社区成员

5.4w+

社区内容

Oracle开发相关技术讨论
社区公告
暂无公告