oracle的PLS-00231 错误分析

oracle的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函数。
create or replace package body PKG_TEST is
    function Two
  return Number
    is
   begin
     return 2;
  end Two;
   procedure PrintTwo
   is
     myNum Number;
   begin
  --    select Two()
  --    into myNum
  --    from dual;
       myNum := Two();
     dbms_output.put_line(myNum);
    end PrintTwo;
 end PKG_TEST;
3,传参数
v_info_01 := fun_vaild_customer(v_customer_id);



你可能感兴趣的:(oracle的PLS-00231 错误分析)