oracle存储过程select into没有查到数据被NO_DATA_FOUND异常捕获

 

a number(10);
b number(10);
c varchar(20);
begin
  select age, sex, name into a, b, c from myemp t where t.empno = pno;
EXCEPTION
  WHEN NO_DATA_FOUND THEN
  dbms_output.put_line('捕获到异常'); 
END;

       最开始接触到存储过程中这种异常的捕获时,我有以为过是当获取到的这条数据的需要取的某个字段为空时触发,也就是当age、sex、name中有一个为空的时候触发。但实际情况不是这样,这三个字段是否为空与是否被NO_DATA_FOUND异常捕获到没有直接关系,只有当一条数据都没有查出来的时候会捕获这个异常。

你可能感兴趣的:(数据库)