PLS-00231

create or replace function Two
      return Number
      is
      begin
        return 2;
      end Two;
create or replace  procedure PrintTwo
      is
       myNum Number;
     begin
      select Two()
      into myNum
      from dual;
      dbms_output.put_line(myNum);
    end PrintTwo;
以上函数和过程,放在函数和过程中声明,调用正常。注意two函数被printtwo过程以sql语句形式调用。

若将此二程序段放入一个package中,函数私有方式,则包体编译时出错,报pls-00231错误,函数不能在sql语句中使用之类。

原因为何?

pl sql和sql对于oracel而言,是两个不同的引擎,因而对于sql引擎而言,plsql包中私有的two函数,是无法发现的。

所以包中使用two函数,方法有两种:

1 在包头声明中声明two函数,即将two函数作公有声明,此时可以select two into mynum from dual;形式调用,当然这样将无法隐藏two函数。

2 以mynum:=two;方式调用,由于此种方式以pl sql引擎解析,所以可以正常使用以私有方式声明的two函数。

可见需以合适的方式将two函数暴露给sql或plsql引擎方可使用。那么若不将two作公有声明,而用包名.two方式调用,不一样可定位到two函数?哦当然不行,你忘了two未作公有声明,在包外无论如何都是不可见。。。。。。。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值