微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决带有 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 添加主键来解决这个问题。 但是,我仍然不知道为什么这解决了问题。如果有人知道原因或可以将我链接到进一步解释这一点的来源,请告诉我。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?