0

我刚刚手动将外键 ID 添加到我的实体中。

我的 UserProfile 实体曾经具有以下属性:

public virtual UserProfile Referer { get; set; }

所以现在我的 UserProfile 实体具有以下属性:

[ForeignKey("Referer")]
public int? RefererId { get; set; }

public virtual UserProfile Referer { get; set; }

但是,当我更新数据库时,出现以下错误:

序列不包含任何元素

Referer UserProfile 应该是可选的,这就是我标记 int? 的原因。

这里有什么问题?

编辑 UserProfile ID 字段如下所示:

[Key]
[DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
public int UserId { get; set; }
4

1 回答 1

1

我认为您滥用了ForeignKey属性。它应该应用于您的虚拟财产以定义包含RefererId.
所以在你的情况下,它应该是这样的:

public int? RefererId { get; set; }

[ForeignKey("RefererId")]
public virtual UserProfile Referer { get; set; }

更新
我想这应该是一对多的关系。所以你必须更新你的类以获得相应的结构。我创建了具有几乎相同结构的示例解决方案:

    public class Person
    {
        [Key]
        public int Id { get; set; }
        public int PersonId { get; set; }

        [ForeignKey("PersonId")]
        public Person Supervisor { get; set; }

        public virtual ICollection<Person> SupervisedPersons { get; set; }
    }

    public class PersonDataContext : DbContext
    {
        public DbSet<Person> Persons { get; set; }
        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            base.OnModelCreating(modelBuilder);
            modelBuilder.Entity<Person>()
                .HasKey(x => x.PersonId)
                .HasOptional(op => op.Supervisor)
                .WithMany(p => p.SupervisedPersons)
                .WillCascadeOnDelete(false);
        }
    }
于 2013-08-12T13:06:06.280 回答