39

我有例外

已检测到关系 y 的角色 x 的冲突更改。

每次我将我的实体添加到我的上下文中

Database.MyEntitys.Add(MyEntity);

MyEntity 类包含此属性:

public virtual ICollection<DetailInfo> Group { get; set; }

DetailInfo 类非常简单:

public class DetailInfo:BaseEntity {
    public virtual Detail Detail { get; set; }
    public decimal Total { get; set; }
    public virtual MyEntity MyEntity { get; set; }
}

DatabaseContext 也很简单:

public class MyEntityConfiguration : EntityTypeConfiguration<MyEntity> {
    public MyEntityConfiguration() {
        HasMany(e => e.Group).WithRequired(s => s.MyEntity).WillCascadeOnDelete(true);
    }
}

public class DetailInfoConfiguration : EntityTypeConfiguration<DetailInfo> {
    public DetailInfoConfiguration() {
        HasRequired(x => x.MyEntity).WithMany(s => s.Group);
        HasRequired(x => x.Detail);
        HasKey(s => s.ID);
        ToTable("DetailInfo");
    }
}

在数据库端,表 MyEntity 具有列 ID 的主键。DetailInfo 还有一个称为 ID 的主键。DetailInfo 包含 2 个 FK,一个到 MyEntity,一个到另一个实体 Detail。

在有问题的场景中,MyEntity 是新的有一个新的细节。我期待 MyEntity 的新条目具有新的详细信息并正确设置所有 FK。

编辑:

这是插入:

public virtual int Insert(MyEntity myEntity) {

    if (myEntity.Group != null && myEntity.Group.Count() == 0) {
        myEntity.Group = null; 
    }

    if (myEntity.Group != null) {
        foreach (var g in myEntity.Group)
        {
         if (g.PropertyOneToOne != null) {
                if (g.PropertyOneToOne.ID == 0) {
                    myEntity.PropertyOneToOne = null;
                }
                else {
                    if (!Database.PropertyOneToOnes.Local.Any(e => e.ID == g.PropertyOneToOne.ID)) {
                        Database.PropertyOneToOnes.Attach(g.PropertyOneToOne);
                    }
                    myEntity.PropertyOneToOne = Database.PropertyOneToOnes.Local.Single(e => e.ID == g.PropertyOneToOne.ID);
                }
            }
            else {
                myEntity.PropertyOneToOne = null;
            }
        }
    }
    Database.MyEntitys.Add(myEntity);
}
4

3 回答 3

50

问题是这个:

MyEntity 的 ID 为 0,因为它是新的 MyEntity。该组也是新的,包含对 MyEntity 的引用。

因此,MyEntity包含一个 Group 列表,其中包含对 的引用MyEntity

问题是这MyEntity.Group.MyEntity似乎与MyEntity. 在将 MyEntity 添加到上下文时,它发现了冲突。

为了解决这个问题,我设置Group.MyEntity为 NULL 并将 Group 的引用保留在MyEntity. 保存时,将MyEntity参考 (ID) 设置到组表中。

我不确定这是最干净的方法,但问题终于解决了。

于 2012-08-14T13:08:30.823 回答
1

其他一些解决方案可能是我们需要配置 2 路绑定数据,因为 MyEntity 需要 Group 而 Group 有 MyEntity。您可以参考此链接来配置双向绑定。希望能帮助到你。EF 5.0 Code First 双向导航,子项中没有外键 ID

于 2015-06-26T16:33:52.627 回答
0

问题也可能是您正在创建一个新的子列表,并且您正在将该列表分配给父列表的多个项目,解决方案是您应该为每个父项目创建一个新的子列表。

于 2017-04-05T07:08:08.887 回答