EF部分字段更新,忽略为null字段
Posted 为乐而来
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了EF部分字段更新,忽略为null字段相关的知识,希望对你有一定的参考价值。
一般的更新代码是这样的
public T Update<T>(T entity) where T : ModelBase { var set = this.Set<T>(); set.Attach(entity); this.Entry<T>(entity).State = EntityState.Modified; this.SaveChanges(); return entity; }
但是有时候有更新的时候,如果为null则不更新这字段,这个时候就会有问题了,这个时候用另一个方法。。
public T Update2<T>(T entity) where T : ModelBase { var set = this.Set<T>(); set.Attach(entity); foreach (System.Reflection.PropertyInfo p in entity.GetType().GetProperties()) { if (p.GetValue(entity) != null) { this.Entry<T>(entity).Property(p.Name).IsModified = true; } } this.SaveChanges(); return entity; }
以上是关于EF部分字段更新,忽略为null字段的主要内容,如果未能解决你的问题,请参考以下文章
将可为空的 DateTime 字段更新为 null 会导致默认 DateTime 值 (0001-01-01 00:00:00.0000000)