我正在使用EFCore 3.0和数据库优先方法,并且想知道如何生成Model
名称。首先,我使用-DataAnnotations
和-Force
开关,命令看起来像这样:
Scaffold-DbContext "data source=foo;initial catalog=bar;integrated security=True;MultipleActiveResultSets=True;App=EntityFramework;Connection Timeout=300;Application Name=FooBar" Microsoft.EntityFrameworkCore.SqlServer -OutputDir Entities/Bar -ContextDir DbContexts -Context BarContext -Tables "Cars", "Makes", "Types" -DataAnnotations -Force
Scaffold-DbContext
创建的C#模型与数据库中的表完全相同。因此它将创建3个类:Cars.cs
,Makes.cs
和Types.cs
。
我的问题是:我们可以自定义这些名称吗?我可以生成类Auto.cs
而不是Cars.cs
吗?
此任务看起来很琐碎,因为从人的角度来看,它是此算法:
运行Scaffold-DbContext
将Cars.cs
类重构为Auto.cs
完成。最终结果:
[Table("cars")]
public partial class Auto
{
public Auto()
{
}
}
因此,如果我第一个问题的答案是“否”。我的后续问题是:我们可以以某种方式使其自动化吗?这确实不是一个复杂的任务。如果我们将命令行更改为:
-Tables "Cars" as "Auto", "Makes" as "Make", "Types" as "Type
是否可以更改/覆盖Scaffold-DbContext
命令?有人做过吗?谢谢!
答案 0 :(得分:1)
使用EF Core Power Tools,您可以自定义重命名:https://github.com/ErikEJ/EFCorePowerTools/wiki/Reverse-Engineering#custom-renaming-with-epftrenamingjson