簡體   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