首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用graphdiff的条件映射

使用graphdiff的条件映射
EN

Stack Overflow用户
提问于 2015-09-09 17:30:43
回答 2查看 941关注 0票数 35

我的DbContext中有以下实体

代码语言:javascript
复制
public class A
{
   public A()
   {
       Bs = new List<B>(); 
   }

   public ICollection<B> Bs { set; get; }
}   

有时我想更新a图:

代码语言:javascript
复制
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 (也更新CDE )使用graphdiff

代码语言:javascript
复制
dbContext.UpdateGraph(a,map=>map.OwnedCollection(x=>x.Bs));

这会更新AB%s、C%s、D%s,但不会更新E%s。

因此,我认为,我需要为graphdiff定义一个条件映射,以更新E,例如:

代码语言:javascript
复制
dbContext.UpdateGraph(a,map=>map.OwnedCollection(x=>x.Bs.OfType<D>(), 
                                             with =>with.OwnedCollection(t=>t.Es))
                                .OwnedCollection(x=>x.Bs.OfType<C>()));

有没有办法做这项工作?

EN

回答 2

Stack Overflow用户

发布于 2015-09-28 18:30:44

您可以将其与graphdiff一起使用:

代码语言:javascript
复制
dbContext.UpdateGraph(a, map => map
    .OwnedCollection(b => p.Bs, with => with
    .AssociatedCollection(p => p.Es)));

请参阅此链接:GraphDiff Explanation

票数 1
EN

Stack Overflow用户

发布于 2015-10-01 22:01:40

我不认为使用您当前的类结构是可能的。但是,我找到了一种方法来实现这一点,但是您必须对代码进行一些更改。

更新A

代码语言:javascript
复制
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; }       
} 

更新BCD

代码语言:javascript
复制
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策略,一些映射是必要的。

代码语言:javascript
复制
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"));

现在,您拥有了几乎相同的数据库结构。CD仍然映射到同一个表。

最后,更新Graph:

代码语言:javascript
复制
context.UpdateGraph(a, map => map
    .OwnedCollection(b => b.Cs)
    .OwnedCollection(b => b.Ds, with => with
        .AssociatedCollection(e => e.Es)));

希望它能帮上忙!

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32475914

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档