0

Scaffold-DbContext在我正在为其创建模型的 Oracle 数据库中进行了一些更改后,我试图通过运行命令来更新我的 ASP.NET Core 应用程序中的模型。在那个数据库中,我有一个表,它有一个自动递增的 ID 作为主键,还有一些属性。出于说明目的,我们将其命名为“T_EXAMPLES”。然后我有另外两个表,一个称为“T_EXAMPLES_CONFIGURATIONS”,其中包含第一个表的 n 个配置,另一个称为“T_EXAMPLES_DATA”,其中包含第一个表的数据。对于 T_EXAMPLES 中的每个条目,其他两个表中可以有多个数据条目和多个配置。运行时Scaffold-DbContext -Connection Name=ConnectionName -Provider "Oracle.EntityFrameworkCore" -OutputDir "Model" -Context "TestContext" -ContextDir "DataAccess" -Force -Verbose,两个表的外键输出完全相同:

Data table:
Found foreign key on table: FK_EXAMPLES_DATA#ID, name: EXAMPLE.T_EXAMPLES_DATA, principal table: EXAMPLE.T_EXAMPLES, delete action: NO ACTION.
2021-02-10 11:10:47.310632 ThreadID:1   (MAP)     OracleDatabaseModelFactory.GetForeignKeysCombined() : tableName: T_EXAMPLES_DATA, tableSchema: EXAMPLE, principalTableName: T_EXAMPLES, principalTableSchema: EXAMPLE, columnName: ID, principalColumnName: ID

Configuration table:
Found foreign key on table: FK_EXAMPLES_CONFIGURATION#ID, name: EXAMPLE.T_EXAMPLES_CONFIGURATIONS, principal table: EXAMPLE.T_EXAMPLES, delete action: NO ACTION.
2021-02-10 11:10:47.311297 ThreadID:1   (MAP)     OracleDatabaseModelFactory.GetForeignKeysCombined() : tableName: T_EXAMPLES_CONFIGURATIONS, tableSchema: EXAMPLE, principalTableName: T_EXAMPLES, principalTableSchema: EXAMPLE, columnName: ID, principalColumnName: ID

但是,当我在运行命令后查看 T_EXAMPLES 的模型时,配置只有一个集合属性,而数据则没有:

public partial class TExamples
{
    public TExamples()
    {
        TExamplesConfigurations = new HashSet<TExamplesConfigurations>();
    }

    public decimal Id { get; set; }

    // ...

    public virtual ICollection<TExamplesConfigurations> TExamplesConfigurations { get; set; }
}

为什么没有为数据创建集合,我该如何解决这个问题?

4

1 回答 1

0

我能够通过向表 T_EXAMPLES_DATA 添加主键来解决这个问题。但是,我仍然不知道为什么这解决了这个问题。如果有人知道原因或可以将我链接到进一步解释这一点的来源,请告诉我。

于 2021-02-10T11:28:26.003 回答