由于模型关系而添加控制器时出错
Posted
技术标签:
【中文标题】由于模型关系而添加控制器时出错【英文标题】:Error Adding Controller because of Model Relationships 【发布时间】:2020-01-22 00:34:16 【问题描述】:我在尝试添加控制器时(可能是)因为定义不正确的关系而收到错误消息。我找不到我的问题。
我有两个简单的模型:场景和条件。一个场景可以由多个条件组成,但一个条件只能与一个场景相关联。 (我的 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;
我希望能够使用代码生成器添加条件控制器而不会遇到错误消息,并且能够返回带有关联条件列表的场景对象,反之亦然。
【问题讨论】:
【参考方案1】:我认为无法使用代码生成器添加控制器的问题是由于我在 OnModelCreatingMethod() 中定义与 Fluent API 的关系的方式存在问题。我摆脱了这些,错误就消失了。事实证明,为了使控制器实际运行,它们并不是强制性的。
我还有另一个问题... .Includes() 语句无法实际加载相关实体。至少在可能的情况下,该问题的答案在这里:
ASP.NET Core API only returning first result of list
【讨论】:
以上是关于由于模型关系而添加控制器时出错的主要内容,如果未能解决你的问题,请参考以下文章
在 codeigniter 的控制器中加载模型时出错消息:未定义的属性:Cart::$load