我有以下实体DbContext:
public class A
{
public A()
{
Bs = new List<B>();
}
public ICollection<B> Bs { set; get; }
}
有时我想更新a图表:
var a = dbContext.As
.AsNoTracking()
.Include(x=>x.Bs)
.firstOrDefault();
var c = new C();
a.Bs.Add(c);
var d = new D();
var e1 = new E();
var e2 = new E();
d.Es.Add(e1); //<-- added new E
d.Es.Add(e2); //<-- added new E
a.Bs.Add(d);
我想a用它的更新(Bs更新,,,C太)使用:DEgraphdiff
dbContext.UpdateGraph(a,map=>map.OwnedCollection(x=>x.Bs));
这会更新A, Bs, Cs, Ds,但不会更新Es。
所以我认为,我需要定义一个条件映射graphdiff来更新Es,例如:
dbContext.UpdateGraph(a,map=>map.OwnedCollection(x=>x.Bs.OfType<D>(),
with =>with.OwnedCollection(t=>t.Es))
.OwnedCollection(x=>x.Bs.OfType<C>()));
有什么办法可以完成这项工作吗?
