天查询一些内容,发现一些内容不对头,找来找去,发现是select into 的问题。
原来的代码是这样的,外面的大循环就不再多写了(我的环境是9iR2)
begin
--获得自己的基本信息
SELECT ParentCode,ID,grade INTO V_ParentCode,
V_ID,V_GRADE FROM TDEPTS WHERE DEPTCODE=P_DEPTCODE;
BEGIN
--Oracle 的 bug还是问题了?
SELECT ParentCode INTO V_ParentCode FROM TDEPTS WHERE FID=V_ID AND ROWNUM<=1;
EXCEPTION
WHEN OTHERS THEN
null
END;
exception
when others then
--当作没有下级
return 1;
end;
在调试的时候,发现变量V_ParentCode还是保留了原来的内容(原来不是空的),这样导致在后来的操作中出现了自己意料之外的内容。
例如上次调用的时候V_PARENTCODE='0001',本次调用返回异常,则V_PARENTCODE还是'0001';
不得已,进行了一些调整:
---------------------------
begin
SELECT ParentCode,ID,grade INTO V_ParentCode,
V_ID,V_GRADE FROM TDEPTS WHERE DEPTCODE=P_DEPTCODE;
BEGIN
SELECT ParentCode INTO V_SUBParentCode FROM TDEPTS WHERE FID=V_ID AND ROWNUM<=1;
EXCEPTION
WHEN OTHERS THEN
V_SUBParentCode:=NULL; --必须手工设置为null,否则可能保持原来的内容
--到底是什么意思
END;
exception
when others then
--当作没有下级
return 1;
end;
最重要的改动是红色字体部分。 V_SUBParentCode初始化的时候是空的。所以,如果没有数据的话,还是空的。
结果就对了。 但为什么这样了? 难道是因为有了意外处理?。。。。
--
后来发现在10g中也是如此,这么看来,只能是说,select into 的过程是分两步的:
1)查询出数据,如果有异常,引发异常.
2)把查询的结果赋予变量.
在第一步中如果没有活得数据则直接的跳跃到异常处理部分,只有这样的解释才能说明为什么变量还是保留前次的状态.