PLSQL命名作用域的窍门节能
民生评论 2020-10-16 01:28 字号: 大 中 小
很多PL/SQL程序员采用一个命名约定区分不同作用域内的变量,从而确定一个值来自哪个作用域。一个常用的方法是给参数加前缀p_,给局部变量加前缀l_,给全局变量或者包变量加前缀g_。例如:
create or replace function myfunc(p_empno integer) return varchar2
is
l_ename ame%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 varchar2
is
ename ame%type;
begin
select ename into ame
from emp
where empno = pno;
return ame;
end myfunc;
/
show errors;
我知道最少有一个专业组织已经在第二个方法中为其命名约定制定了标准。
这个作用域系统实际上带来了一个奇怪的问题:它意味着如果包名和过程或者函数名一样的话,那么就不可能在这个包内调用与其同名的过程或者函数。
create or replace package p1
as
function test return varchar2;
end p1;
/
show errors;
create or replace package body p1
as
function test return varchar2
as
begin
return 'hello world';
end test;
end p1;
/
show errors;
create or replace package p2
as
function p1 return varchar2;
end p2;
/
show errors;
create or replace package body p2
as
function p1 return varchar2
as
return st;
end p1;
end p2;
/
show errors;
Warning: Package Body created with compilation errors.
Errors for PACKAGE BODY P2:
LINE/COL ERROR
-------- ----------------------------------
6/3PL/SQL: Statement ignored
6/13PLS-00302: component莫里斯在进攻抢位中被吹罚了个人第五次犯规 'TEST' must be declared
自己测试一下这些PL/SQL命名作用域系统的窍门,看看你有什么想法。
:李宁
欢迎评论或投稿
中卫白癜风医院哪家治疗好小孩营养不良的症状泰安男科医院哪家好-
-
李娜渴望拿大满贯和世界第一不给自己太大压搭配
李娜:渴望拿大满贯和世界第一 不给自己太大压力即将在香港...
2020-05-29 | 民生评论
-
-
我市召开政策性粮食库存大清查工作部署动员
我市召开政策性粮食库存大清查工作部署动员会 近日,省政...
2019-12-17 | 民生评论
-
-
妈妈你缺席了我的成长却出席了我的审判
妈妈,你缺席了我的成长,却出席了我的审判民生法制3月11日...
2019-07-13 | 民生评论
-
-
新一轮强降雨致南方部分地区再次受灾
新一轮强降雨致南方部分地区再次受灾5月18日以来,南方地区...
2019-07-07 | 民生评论
-
-
麻家渡镇盯紧六类人严守廉政关
麻家渡镇:盯紧六类人 严守廉政关今日竹山网消息 4月18日...
2019-07-06 | 民生评论
-
-
淀山湖镇举办中华慈善日义卖活动
淀山湖镇举办“中华慈善日”义卖活动为纪念《慈善法》颁布...
2019-07-06 | 民生评论