zoukankan      html  css  js  c++  java
  • oracle创建包后执行报错:object omgmig.test_package is invalid.

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

  • 相关阅读:
    字典的key都可以是什么
    groupby 的妙用(注意size和count)

    希尔排序
    TCP和UDP
    闭包(python)
    快速排序
    mysql t4模板_Model
    vue前端性能优化
    系统稳定性问题总结
  • 原文地址:https://www.cnblogs.com/miaoying/p/5850375.html
Copyright © 2011-2022 走看看