繁体   English   中英

由于 Model 关系,添加 Controller 时出错

[英]Error Adding Controller because of Model Relationships

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

我有两个简单的模型:场景和条件。 一个场景可以由多个条件组成,但一个条件只能与一个场景相关联。 (我的 DbContext 是 MySQL,而不是 SQL 服务器)。

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

(我创建 ScenariosController 并从 API 返回数据没有问题。在我期望条件数组的地方,只有 null 值。此外,在尝试添加条件控制器时发生错误。)

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

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

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

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

ASP.NET 核心 API 只返回列表的第一个结果

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM