• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

PL/SQL命名作用域的窍门

发布: 2007-6-21 12:06 | 作者:   | 来源:   | 查看: 29次 | 进入软件测试论坛讨论

领测软件测试网

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

  create or replace function myfunc(p_empno integer) return varchar2
  is
    l_ename emp.ename%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 emp.ename%type;
  begin
    select ename into myfunc.ename
     from emp
     where empno = myfunc.empno;
    return myfunc.ename;
  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 p1.test;
    end p1;
  end p2;
  /
  show errors;
  
  Warning: Package Body created with compilation errors.
  
  Errors for PACKAGE BODY P2:
  
  LINE/COL  ERROR
  
  --------      ----------------------------------
  6/3        PL/SQL: Statement ignored
  6/13       PLS-00302: component 'TEST' must be declared
  
  自己测试一下这些PL/SQL命名作用域系统的窍门,看看你有什么想法。

文章来源于领测软件测试网 https://www.ltesting.net/


关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备10010545号-5
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网