PL/SQL NO_DATA_FOUND、SQL%NOTFOUND、SQL%ROWCOUNT

本文解析了Oracle中NO_DATA_FOUND、SQL%NOTFOUND及SQL%ROWCOUNT的区别。NO_DATA_FOUND异常出现在SELECT INTO语句未找到匹配数据行时等场景;SQL%NOTFOUND属性用于判断是否检索到数据,也可指示UPDATE或DELETE操作未影响任何行;SQL%ROWCOUNT则记录了游标检索的行数。

      今天突然遇到有人问:NO_DATA_FOUND、SQL%NOTFOUND、SQL%ROWCOUNT的区别?所以就说一下我自己的理解吧。

      NO_DATA_FOUND:该异常可以在两种不同的情况下出现:第一种:当SELECT。。。。INTO语句的WHERE子句  没匹配任何数据行时;第二种:试图引用尚未赋值的PL/SQL index-by表元素时。

      SQL%NOTFOUND:是隐匿游标的属性,当没有可检索的数据时,该属性为:TRUE;常作为检索循环退出的条件。

                                    若某UPDATE或DELETE语句的WHERE子句不匹配任何数据行,该属性为:TRUE,但不并不出现NO_DATA_FOUND异常.

      SQL%ROWCOUNT:该数字属性返回了到目前为止,游标所检索数据库行的个数。

我只是对三者做了简单的概念介绍,抛砖引玉!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值