您的位置:首页 > 数据库 > Oracle

ORACLE:写Function时,传入参数变量名的注意事项

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

示例:

CREATE OR REPLACE FUNCTION S_GET_EMP_NAME(EMPNO nvarchar2) return nvarchar2 is
ENAME nvarchar2(100);
begin
SELECT E.ENAME
INTO ENAME
FROM EMP E
WHERE E.EMPNO = EMPNO
AND ROWNUM = 1;
RETURN ENAME;
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"就行了
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: