数据库

位置:IT落伍者 >> 数据库 >> 浏览文章

PL/SQL命名作用域的窍门


发布日期:2018年12月21日
 
PL/SQL命名作用域的窍门

很多PL/SQL程序员采用一个命名约定区分不同作用域内的变量从而确定一个值来自哪个作用域一个常用的方法是给参数加前缀p_给局部变量加前缀l_给全局变量或者包变量加前缀g_例如

create or replace function myfunc(p_empno integer) return varchar

is

l_ename empename%type;

begin

select ename into l_ename

from emp

where empno = p_empno;

return l_ename;

end myfunc;

/

show errors;

PL/SQL有一个有趣的命名作用域系统在这个系统中你可以在一个函数域内通过指定函数或者过程的名字来来访问在函数或者过程中出现的变量这样上面的代码就可以改写为

create or replace function myfunc(empno integer) return varchar

is

ename empename%type;

begin

select ename into myfuncename

from emp

where empno = myfuncempno;

return myfuncename;

end myfunc;

/

show errors;

我知道最少有一个专业组织已经在第二个方法中为其命名约定制定了标准

这个作用域系统实际上带来了一个奇怪的问题它意味着如果包名和过程或者函数名一样的话那么就不可能在这个包内调用与其同名的过程或者函数

create or replace package p

as

function test return varchar;

end p;

/

show errors;

create or replace package body p

as

function test return varchar

as

begin

return hello world;

end test;

end p;

/

show errors;

create or replace package p

as

function p return varchar;

end p;

/

show errors;

create or replace package body p

as

function p return varchar

as

return ptest;

end p;

end p;

/

show errors;

Warning: Package Body created with compilation errors

Errors for PACKAGE BODY P:

LINE/COL ERROR

/PL/SQL: Statement ignored

/PLS: component TEST must be declared

自己测试一下这些PL/SQL命名作用域系统的窍门看看你有什么想法

上一篇:SQL Server日志文件总结及日志满的处理

下一篇:SQL Server 2000的新特色