zoukankan      html  css  js  c++  java
  • ORACLE:写Function时,传入参数变量名的注意事项

    oracle中开发人员写自己的sql function时,入口参数名不要与select中table的字段名重复,否则虽然编译能正常通过,但运行的结果往往是错误的。

    示例:

     1 CREATE OR REPLACE FUNCTION S_GET_EMP_NAME(EMPNO nvarchar2) return nvarchar2 is
     2   ENAME nvarchar2(100);
     3 begin
     4   SELECT E.ENAME
     5     INTO ENAME
     6     FROM EMP E
     7    WHERE E.EMPNO = EMPNO
     8      AND ROWNUM = 1;
     9   RETURN ENAME;
    10 end;

    代码很简单,通过员工号EMPNO,得到员工姓名ENAME。

    测试代码如下:

    SELECT S_GET_EMP_NAME(7654) FROM DUAL;

    返回结果:SMITH

    但是这不是期望的值,EMP中的数据如下:

    SELECT EMPNO,ENAME FROM EMP;

    ----------------------------------------------------

    7369 SMITH
    7499 ALLEN
    7521 WARD
    7566 JONES
    7654 MARTIN
    7698 BLAKE
    7782 CLARK
    7788 SCOTT
    7839 KING
    7844 TURNER
    7876 ADAMS
    7900 JAMES
    7902 FORD
    7934 MILLER

    ----------------------------------------------------

    显然,7654对应不是SMITH,问题在哪呢?

       WHERE E.EMPNO = EMPNO

    这一行条件中,因为变量名EMPNO与表中的字段EMPNO重名了,sql在执行时,认为是 EMPNO这一列在跟自身比较,所以永远是TRUE,最终只有ROWNUM=1起了作用,仅返回了第一行。

    解决办法:

    把function中的入口参数改名,比如加个前缀 “IN_”,变成"IN_EMPNO"就行了

  • 相关阅读:
    Python3 模块
    python os 方法
    python第三方模块的导入
    深拷贝和浅拷贝的区别
    win10专业版激活方法
    Python3 JSON
    python函数
    去重 方法
    VUE-地区选择器(V-Distpicker)组件使用
    ajax
  • 原文地址:https://www.cnblogs.com/yjmyzz/p/2891783.html
Copyright © 2011-2022 走看看