首页 > 代码库 > EF部分字段更新,忽略为null字段

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字段