【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; |
http://mp.weixin.qq.com/s/Vm5PqNcDcITkOr9cQg6T7w |
● 本文作者:小麦苗,只专注于数据库的技术,更注重技术的运用
● 作者博客地址:http://blog.itpub.net/26736162/abstract/1/
● 文章内容来源于作者的学习笔记,部分整理自网络,若有侵权或不当之处还请谅解
● 版权所有,欢迎分享本文,转载请保留出处
长按下图识别二维码或微信扫描下图二维码来关注小麦苗的微信公众号:xiaomaimiaolhr,学习最实用的数据库技术。
本文分享自微信公众号 - DB宝(lhrdba)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。
- 【DB笔试面试602】在Oracle中,如何从执行计划初步判断SQL的性能问题?
- 【DB笔试面试444】Oracle中PL/SQL的流程控制语句包括哪些?
- 数据库笔试面试4——在Oracle中,PL/SQL……
- Oracle PL/SQL判断两个字段相等或不等问题
- Oracle PL/SQL判断两个字段相等或不等问题
- 【DB笔试面试108】在Oracle中,sqldlr true 。。。SQL*Loader utility?()
- 【DB笔试面试109】在Oracle中,Which 。。。conventional path of SQL*Loader?()
- Oracle>>通过PL/SQL程序块判断,指定用户的指定数据表和序列是否存在,如果存在则删除,否则新创建。并且为表添加含有字符串数据,execute immediate执行insert语句中有字符串...
- 【DB笔试面试458】在Oracle中,如何判断一个字符串是否全为数字?
- ORACLE PL/SQL Developer工具执行计划无COST和cardinality,bytes等列值显示问题
- 【DB笔试面试66】在Oracle中,关于锁,下列描述不正确的是()
- 【DB笔试面试119】在Oracle中,Identify three key features of ASM()
- 不安装Oracle客户端,透过PL/SQL Developer连接Server DB
- 【DB笔试面试271】在Oracle中,RAC数据库和单实例数据库有什么区别?
- 【DB笔试面试854】在Oracle中,删除数据库的方式有哪几种?
- 【DB笔试面试223】在Oracle中,如果丢失一个数据文件而且没有备份,也没有归档日志,那么应该如何打开数据库?
- 【DB笔试面试253】在Oracle中,有哪些角色可以管理ASM实例,它们之间的区别有哪些?
- 【DB.Oracle】PL/SQL Developer 与tnsnames.ora文件
- oracle pl/sql中 执行带 OUT 的存储过程
- Oracle - EBS: SQL&PL/SQL 如何根据flag参数决定是否按照某些字段group分组