FireDAC][Phys][ODBC][SQLSRV32.DLL] SQL_NO_DATA FDquery

根据你的描述,出现 SQL_NO_DATA 错误通常是因为应用程序试图删除一条数据库里已经不存在的记录,但这个操作本身并不一定是程序错误。

🔍 问题原因分析

综合搜索结果和常见的FireDAC应用场景,这个错误通常发生在以下情况:

  • 数据已被删除 :最常见的原因是,你的应用程序正尝试使用 ApplyUpdates 等提交一个缓存起来的删除操作,但目标记录在此期间已经被其他用户或进程从数据库中删除了。FireDAC执行删除语句后,发现没有影响任何行(即"没有数据被删除"),就会触发这个错误-1

  • 触发器或存储过程干扰 :当对表执行操作(尤其是插入操作)时,如果该表上存在触发器,并且触发器内部进行了其他数据操作,也可能导致驱动程序返回 SQL_NO_DATA 状态-5

  • ODBC驱动程序处理机制 :从底层的ODBC机制来看,SQL_NO_DATA 也是一个标准返回码,表示"没有可用信息",在遍历完所有结果集或执行某些操作未影响数据行时可能出现-9

🛠️ 解决方法

针对"删除不存在记录"这个主要情况,你可以通过以下几种方式来处理这个异常:

1. 忽略无害的删除错误

这是最直接的方案。你可以在 TFDQueryOnUpdateError 事件中捕获错误,并判断如果是删除操作未找到记录,则手动标记该错误已处理。

pascal

复制

下载

复制代码
procedure TForm1.FDQuery1UpdateError(ASender: TDataSet; AException: EFDException;
  ARow: TFDDatSRow; ARequest: TFDUpdateRequest; var AAction: TFDErrorAction);
begin
  // 判断是否为删除操作且错误是SQL_NO_DATA
  if (ARequest = arDelete) and (AException is EFDDBEngineException) then
  begin
    // 你可以在这里检查更具体的错误代码,但通常针对这种情况直接忽略是安全的
    AAction := eaApplied; // 告知FireDAC此错误已处理,更新成功
  end;
end;

代码逻辑参考自Stack Overflow上的讨论-1

2. 调整FireDAC的更新选项

设置 TFDQuery.UpdateOptions.CountUpdatedRecords 属性为 False。这可以阻止FireDAC去严格检查每次更新操作所影响的行数,从而可能避免此错误-5。但请注意,这可能会掩盖其他本应被发现的更新问题。

3. 在数据库层面设置(如果因触发器引起)

如果错误是由于表上的 插入或更新触发器 引起的,另一个方案是修改触发器,在其开头添加 SET NOCOUNT ON; 语句。这会阻止SQL Server返回受影响的行数信息,从而避免FireDAC产生混淆-5

sql

复制

下载

复制代码
CREATE TRIGGER YourTriggerName
ON YourTableName
AFTER INSERT
AS
BEGIN
    SET NOCOUNT ON; -- 添加这行
    -- ... 触发器其他逻辑
END

💡 如何选择方案

  • 如果你的应用场景是多用户并发操作,数据可能被他人提前删除 ,推荐使用 方法1。它精准地处理了特定情况,不影响其他错误的正常报告。

  • 如果经过排查,确认错误只发生在特定有触发器的表 上,可以考虑 方法3

  • 方法2 作为一种通用设置,可能会带来副作用,建议在明确影响范围后谨慎使用。

如果需要进一步分析,可以告诉我你执行删除操作的具体代码逻辑,这有助于判断问题是否由其他原因引起。

相关推荐
蜂蜜黄油呀土豆1 小时前
MySQL Undo Log 深度解析:表空间、MVCC、回滚机制与版本演进全解
数据库·mysql·innodb·redo log·mvcc·undo log·事务日志
leoufung2 小时前
LeetCode 433:Minimum Genetic Mutation 题目理解与 BFS 思路详解
数据库·leetcode·宽度优先
张3蜂2 小时前
SQL Server 数据库 的通信加密配置SSL安全连接
数据库·安全·ssl
卿雪2 小时前
Redis 数据过期删除和内存淘汰策略
数据库·redis·缓存
by__csdn2 小时前
第一章 (ASP.NET Core入门)第二节( 认识ASP.NET Core)
数据库·后端·c#·asp.net·.net·.netcore·f#
爬山算法2 小时前
Redis(170)如何使用Redis实现分布式限流?
数据库·redis·分布式
JavaBoy_XJ2 小时前
Redis在 Spring Boot 项目中的完整配置指南
数据库·spring boot·redis·redis配置
KG_LLM图谱增强大模型2 小时前
SciDaSynth:基于大语言模型的科学文献交互式结构化数据提取系统
数据库·人工智能·大模型·知识图谱
凌盛羽2 小时前
用Python非常流行的openpyxl库对Excel(.xlsx格式)文件进行创建、读取、写入、显示等操作
数据库·python·链表·excel