我的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);我想用它的Bs更新a (也更新C,D,E )使用graphdiff
dbContext.UpdateGraph(a,map=>map.OwnedCollection(x=>x.Bs));这会更新A、B%s、C%s、D%s,但不会更新E%s。
因此,我认为,我需要为graphdiff定义一个条件映射,以更新E,例如:
dbContext.UpdateGraph(a,map=>map.OwnedCollection(x=>x.Bs.OfType<D>(),
with =>with.OwnedCollection(t=>t.Es))
.OwnedCollection(x=>x.Bs.OfType<C>()));有没有办法做这项工作?
发布于 2015-09-28 18:30:44
您可以将其与graphdiff一起使用:
dbContext.UpdateGraph(a, map => map
.OwnedCollection(b => p.Bs, with => with
.AssociatedCollection(p => p.Es)));请参阅此链接:GraphDiff Explanation
发布于 2015-10-01 22:01:40
我不认为使用您当前的类结构是可能的。但是,我找到了一种方法来实现这一点,但是您必须对代码进行一些更改。
更新A
public class A
{
public A()
{
Cs = new List<C>();
Ds = new List<D>();
}
//PK
public int AId { get; set; }
public ICollection<C> Cs { set; get; }
public ICollection<D> Ds { set; get; }
} 更新B、C和D
public class B
{
public int BId { get; set; }
}
public class C : B
{
//FK that links C to A
public int FK_C_AId { get; set; }
}
public class D : B
{
//FK that links D to A
public int FK_D_AId { get; set; }
public ICollection<E> Es { get; set; }
public D()
{
Es = new List<E>();
}
}为了维护TPH策略,一些映射是必要的。
modelBuilder.Entity<A>()
.HasMany(i => i.Cs)
.WithRequired()
.HasForeignKey(i => i.FK_C_AId)
.WillCascadeOnDelete(false);
modelBuilder.Entity<A>()
.HasMany(i => i.Ds)
.WithRequired()
.HasForeignKey(i => i.FK_D_AId)
.WillCascadeOnDelete(false);
modelBuilder.Entity<B>()
.Map<C>(m => m.Requires("Discriminator").HasValue("C"))
.Map<D>(m => m.Requires("Discriminator").HasValue("D"));现在,您拥有了几乎相同的数据库结构。C和D仍然映射到同一个表。
最后,更新Graph:
context.UpdateGraph(a, map => map
.OwnedCollection(b => b.Cs)
.OwnedCollection(b => b.Ds, with => with
.AssociatedCollection(e => e.Es)));希望它能帮上忙!
https://stackoverflow.com/questions/32475914
复制相似问题