排查 EF 保存数据时提示:Validation failed for one or more entities 的问题

前言

今天有一个使用 EF 的项目遇到了一个这样的异常问题:"Validation failed for one or more entities. See 'EntityValidationErrors' property for more details."

这个错误提示表明,在尝试将实体保存到数据库时,一个或多个实体的验证失败了。但是,错误消息本身并没有提供足够的详细信息来指出是哪个具体的属性或字段导致了验证失败,而且这个表的字段比较多不好一个一个的去排查具体是哪个字段的问题。这里分享一个比较实用的技巧,能够帮助我们快速定位数据验证错误问题。

排查方法

以下这段代码的目的是为了在使用 EF 进行数据库操作时,提供一个优雅的方式来捕获和处理验证失败的情况,同时提供详细的错误信息以帮助开发者快速定位问题。

  • EntityValidationErrors: 包含了所有验证失败的实体的错误信息。

  • ValidationErrors: 包含了验证失败的实体所有属性的验证错误(DbValidationError),例如必填字段未赋值、长度超限等。每个错误会明确标注 PropertyName(属性名)和 ErrorMessage(错误原因)。

    复制代码
              try
              {
                  // .....
    
                  // 数据库操作(例如 SaveChanges())
              }
              catch (DbEntityValidationException ex)
              {
                  foreach (var entityError in ex.EntityValidationErrors)
                  {
                      Console.WriteLine($"实体名称: {entityError.Entry.Entity.GetType().Name}");
                      foreach (var validationError in entityError.ValidationErrors)
                      {
                          // 输出具体错误信息
                          Console.WriteLine($"属性名称: {validationError.PropertyName}");
                          Console.WriteLine($"错误原因: {validationError.ErrorMessage}");
                      }
                  }
                  throw; // 重新抛出异常或处理
              }
相关推荐
AOwhisky3 分钟前
学习自测与解析:MySQL第五、六、七期核心知识点详解
运维·数据库·笔记·学习·mysql·云计算
阿标在干嘛13 分钟前
政策平台的推送系统:消息队列、定时任务、AB测试的工程实践
服务器·数据库·ab测试
Upsy-Daisy23 分钟前
Hermes Agent 学习笔记 02:安装、配置与第一次运行
java·前端·数据库
Tongpao_SSDHDD1 小时前
希捷酷鹰ST6000VX008实测解析:中小安防监控高性价比存储方案
大数据·数据库·人工智能
深海潜水员1 小时前
【从零开始的C#游戏开发课程】- FarmStory1.0 日志系统和游戏资源的管理
游戏·c#·monogame
蓝鸟19741 小时前
Oracle超大DMP备份文件瘦身、日志精简、磁盘空间优化实战方案日志
数据库·oracle·数据库运维·生产运维实战·oracle避坑·磁盘空间优化·oracle日志清理
叶帆1 小时前
【YFIOs】用C#开发硬件之WiFi网络
开发语言·网络·c#
金融支付架构实战指南2 小时前
CQRS + 命令模式 + 事件驱动 + 数据库持久化
数据库·ddd·命令模式·领域驱动模型
sevenll072 小时前
DocKit agentic MongoDB GUI 客户端 - 用自然语言和你的数据对话
数据库·mongodb·nosql·agent·桌面客户端
团象科技2 小时前
从一线实操案例拆解不同出海团队落地海外VPS运维独立站的路径细节
大数据·数据库·人工智能