带有 Oracle.EntityFrameworkCore 提供程序的 Scaffold-DbContext 不创建 ICollection 属性

时间:2021-02-10 10:55:43

标签: c# oracle entity-framework-core scaffolding asp.net-core-scaffolding

在我为其创建模型的 Oracle 数据库中进行了一些更改后,我尝试通过运行 Scaffold-DbContext 命令来更新我的 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; }
}

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

1 个答案:

答案 0 :(得分:0)

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

相关问题