我有一个现有的 EF6
代码库,我正在尝试将其移植到 EF Core
,并且我有一个无法删除/修改的现有数据库。所以我使用以下命令从我的数据库中构建实体类
Scaffold-DbContext "MyConnectionString" Microsoft.EntityFrameworkCore.SqlServer -OutputDir Models
它会生成 DbContext
和必要的实体。现在,他们似乎已经改变了很多命名约定(如何命名实体、属性和导航),而且新创建的实体与我现有的实体有很大不同!我找不到自定义这些约定的方法,所以我不得不在很多地方手动更改代码! (伤心!)
其中一个变化是:现在 EF 不会从表名中单数化类名。例如如果表名是'Accessories',之前的实体类是'Accessory',现在是'Accessories'!
为了解决这个问题,我使用了 IPluralizer界面并使用了Humanizer单数化实体类名称的库。
当我使用 Humanizer
库时,它会这样做
"Accessories".Singularize(); //produces "Accessory"
"XMLDetails".Singularize(); //produces "XMLDetail"
但是,在 EF Core
创建的最终实体类中,第二个属性名称变成了 Xmldetail
,忽略了原来的大小写!有没有办法通过 EF Core 脚手架的过程保留原来的外壳?
注意:我正在使用 Microsoft.EntityFrameworkCore.SqlServer
版本 2.0.1
和一个针对 .NET Standard 2.0
的类库>.
最佳答案
经过一些研究,我从 GitHub 社区了解到,这是一个 known issue在 EF Core 2.0
中,它已经是 fixed在 repo 协议(protocol)中。 此修复计划与 EF Core 2.1
一起发布。
修复发布后,您可以使用 --use-database-names
标志告诉 EF 完全根据数据库名称生成名称,如下所示
Scaffold-DbContext "ConnString" Microsoft.EntityFrameworkCore.SqlServer -o Models --use-database-names
在此之前,您可以尝试以下工具之一,它提供比默认 EF Core
工具更多/更好的选项(我还没有实际使用过它们)
关于c# - 如何首先使用数据库在 EF Core 中自定义实体名称大小写,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48150867/