今天学习了一下oracle的包的写法,然后碰到这么个问题。包声明和包主体都正确,但是就是执行报错:object omgmig.test_package is invalid.

这是会报错的sql,看起来都正常对吧。。但是就是会报错

--包声明
create package omgmig.test_package
as
procedure show1;
end  omgmig.test_package;

--包体
create package body  omgmig.test_package
as
procedure show1
is
begin
for i in 1..9 loop
dbms_output.put_line('i的值为:'||i);
end loop;
end;
end  omgmig.test_package;

begin
 omgmig.test_package.show1;
end;

然后在包名上右击查看,pl/sql下提示错误原因:

可是我在定义的时候明明是加了omgmig前缀的,然后drop这个package,把包名的omgmig前缀都去掉后就执行成功了。因为我当前使用的账号就是omgmig,pl/sql会自动将这个前缀去掉。另外,报错原因是:包名不能包含“.”

 

posted on 2016-09-07 17:54  miaoying  阅读(1560)  评论(0编辑  收藏  举报