如何使用 FluentMigrator 创建一对一的外键

How to create one to one foreign key using FluentMigrator

我正在使用此代码创建外键:

Create.ForeignKey("FK_Table1_Table2")
    .FromTable("Table1").ForeignColumn("Table1_ID")
    .ToTable("Table2").PrimaryColumn("Table2_ID");

因此我有一对多的关系:

public class Table1
{
    public int Table1_ID { get; set; }
    public virtual Table2 Table2 { get; set; }
}


public class Table2
{
    public Table2()
    {
        this.Tables1 = new HashSet<Table1>();
    }
    public int Table2_ID { get; set; }
    public virtual ICollection<Table1> Tables1 { get; set; }
}

但我想看:

public class Table2
{
    public int Table2_ID { get; set; }
    public virtual Table1 Table1 { get; set; }
}

有没有办法使用 FluentMigrator 做到这一点?

关系型数据库对many/one一个外键关系没有特殊的概念。 FK 成为 "one" 的唯一方法是它也具有唯一约束。

所以我相信你应该在外键创建代码之后添加这样的东西:

Create.UniqueConstraint()
    .OnTable("Table1").Column("Table1_ID");