gpt4 book ai didi

c# - 由于模型关系而添加 Controller 时出错

转载 作者:行者123 更新时间:2023-11-29 15:37:56 25 4
gpt4 key购买 nike

由于关系定义不正确,我在尝试添加 Controller (可能)时收到错误消息。我找不到我的问题所在。

我有两个简单的模型:场景和条件。一个场景可以包含多个条件,但一个条件只能与一个场景关联。 (我的 DbContext 是 MySQL,而不是 SQL Server)。

错误:运行所选代码生成器时出错:“具有外键属性 {'ScenarioId: int'} 的从 'Condition' 到 Scenario.Conditions 的关系无法定位主键 {'Id': int},因为它不兼容。为此关系配置主键或一组兼容的外键属性。'

(创建 ScenariosController 并从 API 返回数据没有问题。在我预期的条件数组所在的位置,只有空值。此外,在尝试添加 ConditionsController 时发生了错误。)

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; }
}

我希望能够使用代码生成器添加 ConditionsController,而不会遇到错误消息,并能够返回带有关联条件列表的 Scenario 对象,反之亦然。

最佳答案

我认为无法使用代码生成器添加 Controller 的问题是由于我在 OnModelCreatingMethod() 中定义与 Fluent API 的关系的方式存在一些问题。我摆脱了这些,错误就消失了。事实证明,为了使 Controller 实际运行,它们并不是强制性的。

我还有另一个问题....Inincludes() 语句无法实际加载相关实体。至少在可能的情况下,该问题的答案如下:

ASP.NET Core API only returning first result of list

关于c# - 由于模型关系而添加 Controller 时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58037029/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com