文档章节

EF更新部分实体属性保存时,实体其他属性的验证特型出现验证异常问题的解决办法

夙歆风
 夙歆风
发布于 2016/08/13 23:37
字数 526
阅读 45
收藏 1
EF

       EF的特性允许修改实体的部分属性而不用去查询实体。

       如下代码:

var dbSet = db.Set<Entity>();

var m = new Feedback
{
    Id = 5,
    FunctionPoint = "FunctionPoint",
    Comments = "Comments",
    Contact = "Contact"
};

//将当前实体附加到上下文中
var entity = dbSet.Attach(m);

var entry = db.Entry(entity);
//重置实体状态为没有变化,如同刚从数据库中查询出来一样
entry.State = EntityState.Unchanged;

//设置实体属性
entity.FunctionPoint = "FunctionPoint";
entity.Contact = "Contact";
entity.Comments = "Comments";

//设置某些属性的状态为发生变化
entry.Property(a => a.FunctionPoint).IsModified = true;
entry.Property(a => a.Contact).IsModified = true;
entry.Property(a => a.Comments).IsModified = true;

//保存实体变更
var count = db.SaveChanges();

        但当实体模型的其他属性有诸如Required等验证特性时,执行SaveChanges方法会引起验证错误,因为当前实体的其他属性均为null,无法通过验证。

        网上查到的办法多为将ValidateOnSaveEnabled属性设为false关闭实体的自动验证功能,但此法却也失去了EF带来的实体自动验证的优点。

       本文的办法是通过重写 DbContext 的 ValidateEntity 方法,使其在执行SaveChanges方式保存实体的实体验证时只验证发生了变化的实体属性。(也就是移除所有没有变化的属性的验证错误信息)

protected override DbEntityValidationResult ValidateEntity(DbEntityEntry entityEntry, IDictionary<object, object> items)
{
    //当实体不为null且实体状态为已发生变化时执行
    if (entityEntry != null && entityEntry.State == EntityState.Modified)
    {
        //获取实体验证结果
        var ValidateEntity = base.ValidateEntity(entityEntry, items);
        //获取实体当前属性的属性名称列表
        var PropertyNames = ValidateEntity.Entry.CurrentValues.PropertyNames;
 
        foreach (var PropertyName in PropertyNames)
        {
            //判断当前属性的值是否发生了变化
            if (ValidateEntity.Entry.Property(PropertyName).IsModified == false)
            {
                //如果当前实体属性未发生变化,则查询验证结果中该属性的验证错误信息
                var ve = ValidateEntity.ValidationErrors.FirstOrDefault(a => a.PropertyName == PropertyName);
                //如果获取的该实体当前属性的验证错误信息存在,则从验证错误信息中移除它
                if (ve != null) {
                    ValidateEntity.ValidationErrors.Remove(ve);
                }
                
            }
        }
        //返回最终的验证结果
        return ValidateEntity;
    }
    else
    {
        return base.ValidateEntity(entityEntry, items);
    }
     
}

 

© 著作权归作者所有

共有 人打赏支持
夙歆风
粉丝 0
博文 1
码字总数 526
作品 0
成都
程序员
私信 提问
在EF中使用Expression自动生成p=>new Entity(){X="",Y="",..}格式的Lambda表达式灵活实现按需更新

一、基本介绍 回忆:最早接触Expression是在学校接触到EF的时候,发现where方法里的参数是Expression>这么一个类型,当初也只是看到了,也没有过多的去探究,只是知道传入lambda表达式使用即...

含光君
2018/09/26
0
0
七天学会ASP.NET MVC (三)——ASP.Net MVC 数据处理

第三天我们将学习Asp.Net中数据处理功能,了解数据访问层,EF,以及EF中常用的代码实现方式,创建数据访问层和数据入口,处理Post数据,以及数据验证等功能。 系列文章 七天学会ASP.NET MVC...

葡萄城控件技术团队
2015/06/30
0
0
YMP v2.0.0 发布,轻量级 Java 应用开发框架

自YMP v2.0GA版本发布至今,在经历近一年时间不断的优化完善,今天,正式发布YMP v2.0.0版! YMP是一个非常简单、易用的轻量级Java应用开发框架,涵盖AOP、IoC、WebMVC、ORM、Validation、P...

有理想的鱼
2017/02/07
4.2K
5
ABP之什么是ABP(ASP.NET Boilerplate)

1.介绍 ABP是开源的且文档比较齐全的应用程序框架。其实它不仅仅是个框架,考虑其最佳实践,ABP更提供了基于领域驱动设计(DDD)的强大价格模型。 ABP支持最新的ASP.NET Core和EF Core,同时...

Freda.Han
2018/08/15
0
0
Entity Framework 查漏补缺 (二)

数据加载 如下这样的一个lamda查询语句,不会立马去查询数据库,只有当需要用时去调用(如取某行,取某个字段、聚合),才会去操作数据库,EF中本身的查询方法返回的都是IQueryable接口。 链...

【可乐不加冰】
01/12
0
0

没有更多内容

加载失败,请刷新页面

加载更多

深度学习为图片人物换装【python代码教程】

在观看本文之前,请答应我要善良。昨天预告了下,发现很多同学对这个模型都表示出兴趣,甚至有好多同学后台发来照片让我帮他们脱裤子。授人以鱼不如授人以渔,请这些同学好自为之~ 01效果演示...

阿里云官方博客
26分钟前
2
0
centos7安装RabbitMQ详细过程

由于RabbitMQ是基于Erlang语言开发,所以在安装RabbitMQ之前,需要先安装Erlang 1、环境: centos 7.1 内核版本3.10.0-229.el7.x86_64 Erlang 19.0.4版本 RabbitMQ 3.6.14版本 2、在线安装E...

秋至丶枫以落
57分钟前
1
0
6个使用KeePassX保护密码的技巧

虽然安全是个深奥的主题,但是你可以遵循几个简单的日常习惯来减小攻击面。本文将解释确保密码信息安全的重要性,并给出如何充分利用KeePassX的建议。 日益互联的数字世界使安全成为一个重要...

Linux就该这么学
59分钟前
1
0
UnsatisfiedLinkError sawindbg.dll

方法:搜索sawindbg.dll,然后将文件报错的目录下

洛水
今天
5
0
说说不知道的Golang中参数传递

本文由云+社区发表 导言 几乎每一个C++开发人员,都被面试过有关于函数参数是值传递还是引用传递的问题,其实不止于C++,任何一个语言中,我们都需要关心函数在参数传递时的行为。在golang中...

腾讯云加社区
今天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部