今天学习了一下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会自动将这个前缀去掉。另外,报错原因是:包名不能包含“.”