3

我正在尝试在实体框架中建立一对多关系,其中许多项目之一被可选地指定为默认值。

public class SomeEntity
{
    public int Id { get; set; }
    public Item DefaultItem { get; set; }          // Optional
    public ICollection<Item> Items { get; set; }
}

public class Item
{
    public int Id { get; set; }
    public string ItemName { get; set; }
    public SomeEntity SomeEntity { get; set; }
}

fluent API 中的一对多配置看起来非常简单:

HasMany(e => e.Items).WithRequired(i => i.SomeEntity).WillCascadeOnDelete(true);

但是实现默认项目的解决方案已被证明是难以捉摸的。我尝试了这个(以及各种变体),但没有运气。它告诉我“指定的架构无效”。

HasOptional(e => e.DefaultItem).WithRequired(i => i.SomeEntity);

有任何想法吗?提前致谢。

4

1 回答 1

3

这有点不典型的“设置”(它通常通过项目上的一些“标志”来指定——但我可能会看到需要类似的东西),并将一个项目与同一个父项关联两次。

但是,这应该工作......

modelBuilder.Entity<SomeEntity>()
    .HasOptional(x => x.DefaultItem)
    .WithOptionalPrincipal() // x => x.DefaultForEntity)
    .WillCascadeOnDelete(false);
...
// public SomeEntity DefaultForEntity { get; set; } // optional

...并像这样使用它:

var item = new Item { ItemName = "Default1", };
db.SomeEntities.Add(new SomeEntity { DefaultItem = item, Items = new[]
{
    item,
    new Item{ ItemName = "Item1", },
    new Item{ ItemName = "Item2", },
    new Item{ ItemName = "Item3", },
    new Item{ ItemName = "Item4", },
}
});
db.SaveChanges();
于 2013-04-02T00:37:17.957 回答