当前位置: 首页 > news >正文

Oracle SQL和PL/SQL中SQL%ROWCOUNT和SQL%FOUND属性

在Oracle SQL和PL/SQL中,SQL%ROWCOUNTSQL%FOUND是两个常用的属性,它们各自在不同的上下文中提供关于最近执行的DML(数据操纵语言)语句(如INSERT、UPDATE、DELETE)或SELECT INTO语句的反馈信息。尽管这两个属性都可以用来了解DML操作的结果,但它们提供的信息类型和用途是不同的。

SQL%ROWCOUNT

SQL%ROWCOUNT是一个属性,它返回最近一次DML语句影响的行数,或者是SELECT INTO语句找到的行数(如果使用了SELECT INTO且找到了至少一行)。对于DELETE语句,如果删除了任何行,SQL%ROWCOUNT将返回被删除的行数;如果没有删除任何行(例如,WHERE子句条件不匹配任何行),则返回0。

DROP TABLE employees_temp;CREATE TABLE employees_temp 
AS 
SELECT * FROM employees;DECLARE mgr_no NUMBER(6) := 122;
BEGINDELETE FROM employees_temp WHERE manager_id = mgr_no;DBMS_OUTPUT.PUT_LINE('Number of employees deleted: ' || TO_CHAR(SQL%ROWCOUNT));END;
/

Result:

Number of employees deleted: 8

SQL%ROWCOUNT属性的值与事务的状态无关。因此:

  • 当事务回滚到保存点时,SQL%ROWCOUNT的值不会恢复到保存点之前的值。
  • 当自主事务结束时,SQL%ROWCOUNT不会恢复到父事务中的原始值。

SQL%FOUND

SQL%FOUND是一个布尔类型的属性,用于指示最近一次DML语句或SELECT INTO语句是否影响了或找到了任何行。如果最近一次执行的DML语句(如INSERT、UPDATE、DELETE)影响了至少一行,或者SELECT INTO语句至少找到了一行数据,则SQL%FOUND为TRUE;否则为FALSE。

使用SQL%FOUND来确定DELETE语句是否影响了任何行

如果你想知道一个DELETE语句是否删除了任何行,使用SQL%FOUND是一个直接且清晰的方法。这里有一个简单的例子:

-- 如果存在该则删除,便于观察
DROP TABLE dept_temp;-- 创建测试表
CREATE TABLE dept_temp AS  SELECT * FROM departments;-- 创建存储过程
CREATE OR REPLACE PROCEDURE p (dept_no NUMBER
) AUTHID CURRENT_USER AS
BEGINDELETE FROM dept_tempWHERE department_id = dept_no;IF SQL%FOUND THENDBMS_OUTPUT.PUT_LINE ('Delete succeeded for department number ' || dept_no);ELSEDBMS_OUTPUT.PUT_LINE ('No department number ' || dept_no);END IF;
END;
/
-- 调用存储过程
BEGINp(270);p(400);
END;
/

Result:

Delete succeeded for department number 270
No department number 400

在这个例子中,如果DELETE语句影响了至少一行(即至少有一个员工从部门50中被删除),SQL%FOUND将为TRUE,并输出相应的消息。如果没有员工被删除(例如,部门50中没有员工或所有员工都已符合其他条件),SQL%FOUND将为FALSE,并输出另一个消息。

SQL%NOTFOUND属性:没有行受到影响吗?

SQL%NOTFOUND(与SQL%FOUND的逻辑相反)返回:
  • 如果没有运行SELECT或DML语句,则为NULL
  • 如果SELECT语句返回一行或多行,或者DML语句影响一行或多列,则返回FALSE
  • 否则为真
SQL%NOTFOUND属性在PL/SQL SELECT INTO语句中没有用,因为:
  • 如果SELECT INTO语句不返回任何行,PL/SQL会立即引发预定义的异常no_DATA_FOUND,然后才能检查SQL%NOTFOUND。
  • 调用SQL聚合函数的SELECT INTO语句总是返回一个值(可能为NULL)。在这样的语句之后,SQL%NOTFOUND属性始终为FALSE,因此没有必要进行检查。

总结

虽然SQL%ROWCOUNT提供了影响的行数这一具体信息,但在只需要知道是否影响了任何行的情况下,SQL%FOUND是一个更简单、更直观的选择。因此,在想要确定DELETE语句是否影响了任何行的场景中,使用SQL%FOUND是合适的。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • STM32
  • 【Linux】冯诺依曼概念以及操作系统基础概念
  • Hadoop 下载
  • 集运系统需要与哪些硬件设备集成?
  • QString如何追加字符串
  • 视频安防监控LntonAIServer安防管理平台抖动检测和过亮过暗检测
  • 电工基础知识
  • Mental-LLM——通过在线文本数据利用大型语言模型进行心理健康预测
  • 【路径规划】 使用计算机视觉和机器人操纵器绘制肖像
  • 1-6 图像覆盖掩膜 opencv树莓派4B 入门系列笔记
  • 金融、互联网等领域手机三要素API接口的应用
  • 计算氨基酸残基之间的键角和二面角
  • 基于Python爬虫的淘宝服装数据分析项目
  • Python的math库——常用数学函数全解析
  • 3D 场景模拟 2D 碰撞玩法的方案
  • 2017-09-12 前端日报
  • Android单元测试 - 几个重要问题
  • CSS相对定位
  • Laravel 实践之路: 数据库迁移与数据填充
  • Python3爬取英雄联盟英雄皮肤大图
  • 从0实现一个tiny react(三)生命周期
  • 番外篇1:在Windows环境下安装JDK
  • 给初学者:JavaScript 中数组操作注意点
  • 技术发展面试
  • 聚类分析——Kmeans
  • 聊聊flink的BlobWriter
  • 如何优雅地使用 Sublime Text
  • 温故知新之javascript面向对象
  • 用Visual Studio开发以太坊智能合约
  • # 计算机视觉入门
  • #define MODIFY_REG(REG, CLEARMASK, SETMASK)
  • #Spring-boot高级
  • (1)(1.9) MSP (version 4.2)
  • (14)Hive调优——合并小文件
  • (C语言)二分查找 超详细
  • (Matlab)遗传算法优化的BP神经网络实现回归预测
  • (二)【Jmeter】专栏实战项目靶场drupal部署
  • (二)什么是Vite——Vite 和 Webpack 区别(冷启动)
  • (二刷)代码随想录第16天|104.二叉树的最大深度 559.n叉树的最大深度● 111.二叉树的最小深度● 222.完全二叉树的节点个数
  • (附源码)springboot车辆管理系统 毕业设计 031034
  • (企业 / 公司项目)前端使用pingyin-pro将汉字转成拼音
  • (十二)springboot实战——SSE服务推送事件案例实现
  • (四)软件性能测试
  • (一)搭建springboot+vue前后端分离项目--前端vue搭建
  • (已更新)关于Visual Studio 2019安装时VS installer无法下载文件,进度条为0,显示网络有问题的解决办法
  • (转)scrum常见工具列表
  • (转)四层和七层负载均衡的区别
  • .NET Framework 的 bug?try-catch-when 中如果 when 语句抛出异常,程序将彻底崩溃
  • .NET Micro Framework初体验
  • .Net 访问电子邮箱-LumiSoft.Net,好用
  • .Net 高效开发之不可错过的实用工具
  • .NET 中各种混淆(Obfuscation)的含义、原理、实际效果和不同级别的差异(使用 SmartAssembly)
  • .net 逐行读取大文本文件_如何使用 Java 灵活读取 Excel 内容 ?
  • .NET程序集编辑器/调试器 dnSpy 使用介绍
  • .Net接口调试与案例