首页 > 解决方案 > EF Core Power Tools 逆向工程师在不同 SQL 服务器上的模型上创建不同的属性

问题描述

我正在使用 EF Core Power Tools 通过在 Visual Studio .Net 中选择 EF Core Power Tools -> Reverse Enegineer 来生成我的模型。

我仍在使用 EF Core 2.x,因此我从第一个对话框中删除了复选标记,您可以在其中选择使用 EF Core 3.x。

在最后一个选项对话框中,我选择:

我正在为我的数据库使用 SQL Server。

我的问题是,当我在本地数据库上运行工具时,生成的模型与另一台服务器上的数据库版本不同。

不同之处在于生成的 POCO 类。在我的本地数据库上,生成了以下类:

public partial class ExampleTable
{
    [Key]
    public byte Id { get; set; }
    public string Tekst { get; set; }
} 

当我针对另一个数据库运行该工具时,代码如下所示:

[Table("ExampleTable", Schema = "dbo")]
public partial class ExampleTable
{
    [Key]
    public byte Id { get; set; }
    public string Tekst { get; set; }
}

为什么该工具生成的模型在一个数据库的 dbo 表上具有属性而在另一个数据库上没有属性?

标签: c#entity-framework-coreef-power-tools

解决方案


正如@Karan 所说,这是因为用于脚手架的用户没有 dbo 作为默认模式。

https://github.com/dotnet/efcore/blob/master/src/EFCore.Design/Scaffolding/Internal/CSharpEntityTypeGenerator.cs#L174


推荐阅读