1

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

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

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

  • 使用 DataAnnotation 属性来配置模型。
  • 使用 Handlebars 模板 (C#) 自定义代码。

我正在为我的数据库使用 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 表上具有属性而在另一个数据库上没有属性?

4

1 回答 1

1

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

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

于 2020-07-10T05:25:35.907 回答