如何解决带有 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 举报,一经查实,本站将立刻删除。