gpt4 book ai didi

c# - 如何首先使用数据库在 EF Core 中自定义实体名称大小写

转载 作者:行者123 更新时间:2023-11-30 12:55:33 25 4
gpt4 key购买 nike

我有一个现有的 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 issueEF 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 工具更多/更好的选项(我还没有实际使用过它们)

  1. EF Core Power Tools
  2. EntityFramework-Reverse-POCO-Code-First-Generator

关于c# - 如何首先使用数据库在 EF Core 中自定义实体名称大小写,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48150867/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com