我有以下实体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
太)使用:D
E
graphdiff
dbContext.UpdateGraph(a,map=>map.OwnedCollection(x=>x.Bs));
这会更新A
, B
s, C
s, D
s,但不会更新E
s。
所以我认为,我需要定义一个条件映射graphdiff
来更新E
s,例如:
dbContext.UpdateGraph(a,map=>map.OwnedCollection(x=>x.Bs.OfType<D>(),
with =>with.OwnedCollection(t=>t.Es))
.OwnedCollection(x=>x.Bs.OfType<C>()));
有什么办法可以完成这项工作吗?