【DB笔试面试104】在Oracle中,假定SERV表有a、b、c三个字段。。。判断PL/SQL能否正常执行?

Q          题目如下所示:

  假定SERV表有a、b、c三个字段:SERV(a number(10),b number(10),c number(10))。表SERV的内容如下:

a

b

c

1

10

70

2

30

50

1

10

80

以下两段PL/SQL的功能是根据a的值,查找出对应b的值赋予变量x,请分别判断这两段PL/SQL是否能正常执行,若不能正常执行,请指出错误的原因并修改。

(1)

 
                 
                 declare    x number;begin  select b into x from serv where a=1;  dbms_output.put_line(to_char(x));end;


(2)

               
               



declare 


   x number;


begin


  select b into x from serv where a=2;


  dbms_output.put_line(to_char(x));


end;

    



     
A          答案如下所示:          


       

  这2段程序除了WHERE语句后的值不同以外,其它均一样。对于程序(1),当a=1时,返回了2行记录,对于程序(2),当a=2时,返回了1行记录。对于变量x而言,只能接受一个值,所以,程序2执行不报错,程序(1)执行报错:ORA-01422: exact fetch returns more than requested number of rows。

对于程序(1)有2种修改方法,第一种就是将“select b into x from serv where a=1;”修改为“select distinct b into x from serv where a=1;”。第二种方法就是返回集合类型,修改后的程序块如下所示:


 
                 
                 

DECLARE


  VARCURSOR SYS_REFCURSOR;


  X         SERV%ROWTYPE;


BEGIN


  OPEN VARCURSOR FOR


    SELECT T.* FROM SERV T WHERE A=1;


  LOOP


    FETCH VARCURSOR


      INTO X;


    EXIT WHEN VARCURSOR%NOTFOUND;


    DBMS_OUTPUT.PUT_LINE(R.B);


  END LOOP;


END;

    






DB笔试面试历史连接  
http://mp.weixin.qq.com/s/Vm5PqNcDcITkOr9cQg6T7w




About Me:小麦苗      

● 本文作者:小麦苗,只专注于数据库的技术,更注重技术的运用

● 作者博客地址:http://blog.itpub.net/26736162/abstract/1/

● 文章内容来源于作者的学习笔记,部分整理自网络,若有侵权或不当之处还请谅解

● 版权所有,欢迎分享本文,转载请保留出处


长按下图识别二维码或微信扫描下图二维码来关注小麦苗的微信公众号:xiaomaimiaolhr,学习最实用的数据库技术。

本文分享自微信公众号 - DB宝(lhrdba)。
如有侵权,请联系 [email protected] 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。