由于不正确定义的关系,我在尝试添加控制器时(可能)收到一条错误消息。我找不到我的问题。
我有两个简单的模型:场景和条件。一个场景可以由多个条件组成,但一个条件只能与一个场景相关联。(我的 DbContext 是 MySQL,而不是 SQL Server)。
错误:运行所选代码生成器时出错:'条件'到场景的关系。具有外键属性 {'ScenarioId: int'} 的条件无法定位主键 {'Id': int},因为它不是兼容的。为此关系配置一个主键或一组兼容的外键属性。
(我在创建 ScenariosController 并从 API 返回数据时没有问题。在我期望条件数组的地方,只有空值。此外,尝试添加条件控制器时发生错误。)
public class Scenario
{
public int Id { get; set; }
public string Title { get; set; }
public string Description { get; set; }
public ICollection<Condition> Conditions { get; set; }
}
public class Condition
{
public int Id { get; set; }
public int ScenarioId { get; set; }
public string Type { get; set; }
public string Preference { get; set; }
[ForeignKey("ScenarioId")]
public Scenario Scenario { get; set; }
}
public class EvaluatorContext : DbContext
{
public EvaluatorContext(DbContextOptions<EvaluatorContext> options)
: base(options)
{
}
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<Condition>()
.HasOne(s => s.Scenario)
.WithMany()
.HasPrincipalKey(s => s.Id);
modelBuilder.Entity<Scenario>()
.HasMany(s => s.Conditions)
.WithOne()
.HasForeignKey(c => c.ScenarioId);
}
public DbSet<Scenario> Scenario { get; set; }
public DbSet<Condition> Condition { get; set; }
}
我希望能够使用代码生成器添加条件控制器而不会遇到错误消息,并且能够返回带有关联条件列表的场景对象,反之亦然。