暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

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

DB宝 2017-04-09
903

Q
题目如下所示:

  假定SERV表有abc三个字段: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)

  1. declare 

  2.    x number;

  3. begin

  4.   select b into x from serv where a=1;

  5.   dbms_output.put_line(to_char(x));

  6. end;



(2)


  1. declare 

  2.    x number;

  3. begin

  4.   select b into x from serv where a=2;

  5.   dbms_output.put_line(to_char(x));

  6. 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;”。第二种方法就是返回集合类型,修改后的程序块如下所示:


  1. DECLARE

  2.   VARCURSOR SYS_REFCURSOR;

  3.   X         SERV%ROWTYPE;

  4. BEGIN

  5.   OPEN VARCURSOR FOR

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

  7.   LOOP

  8.     FETCH VARCURSOR

  9.       INTO X;

  10.     EXIT WHEN VARCURSOR%NOTFOUND;

  11.     DBMS_OUTPUT.PUT_LINE(R.B);

  12.   END LOOP;

  13. END;






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




About Me:小麦苗

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

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

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

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


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

最后修改时间:2020-01-10 21:18:24
文章转载自DB宝,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论