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"就行了