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

问题描述

在我为其创建模型的 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,delete action: NO ACTION.
2021-02-10 11:10:47.311297 ThreadID:1   (MAP)     OracleDatabaseModelFactory.GetForeignKeysCombined() : tableName: T_EXAMPLES_CONfigURATIONS,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; }
}

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

解决方法

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

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...