实体框架核心中的两个外键

时间:2018-03-11 18:52:58

标签: asp.net entity-framework asp.net-core entity-framework-core asp.net-core-2.0

我在使用Entity Framework Core创建数据库时使用Code First方法。我想创建两个指向同一个表的外键。 我的示例显示了User表,它将保存userID和Message表,它将同时包含Receiver ID和Sender ID(这意味着两个值都必须指向同一个表)。

用户代码:

public class User
{
    [Key]
    [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
    public int Id { get; set; }

    [Required]
    [MaxLength(50)]
    public string UserName { get; set; }
    [Required]
    [MaxLength(50)]
    public string Password { get; set; }

    public virtual ICollection<Message> MessagesSent { get; set; }
    public virtual ICollection<Message> MessagesReceived { get; set; }
}

对于消息:

public class Message
{
    [Key]
    [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
    public int id { get; set; }

    public User Sender { get; set; }
    public User Receiver { get; set; }
    public int senderId { get; set; }
    public int receiverId { get; set; }

    [MaxLength(500)]
    public string message { get; set; }

}

我使用的是ASP.NET Core 2,我是新手。 我试图使用this解决方案,但不幸的是,我无法设法覆盖OnModelCreating方法。它表明它不存在。

PS。不要介意密码字段,它仅用于测试目的。

谢谢!

1 个答案:

答案 0 :(得分:2)

我设法使用Fluent API。

我的DbContext中的代码:

protected override void OnModelCreating(ModelBuilder modelBuilder)
{
    modelBuilder.Entity<Message>()
        .HasOne(p => p.Receiver)
        .WithMany(t => t.MessagesReceived)
        .HasForeignKey(m => m.ReceiverId)
        .OnDelete(DeleteBehavior.Restrict);

    modelBuilder.Entity<Message>()
        .HasOne(p => p.Sender)
        .WithMany(t => t.MessagesSent)
        .HasForeignKey(m => m.SenderId)
        .OnDelete(DeleteBehavior.Restrict);                
}

更重要的是,我发现了未设置用户删除行为的问题。 有两种方法可以解决它。

首先是在删除用户时保留消息:

.OnDelete(DeleteBehavior.Restrict);

或者第二个将删除消息:

.OnDelete(DeleteBehavior.Cascade);