EFCore 的 DbFirst 模式
2022/4/21 6:22:10
本文主要是介绍EFCore 的 DbFirst 模式,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
1 前言
EF6 时代,可以通过界面操作,添加数据库实体。
EF Core 需要通过 CLI 来进行该操作,具体请参考EF Core官方文档:反向工程。
2 前置条件
-
PMC 工具(仅限 Visual Studio)或 CLI 工具。
-
核心 NuGet 包:Microsoft.EntityFrameworkCore.Design
-
还需要为要进行反向工程的数据库架构安装适当的数据库提供程序
3 主命令
dotnet ef dbcontext scaffold "[数据库连接串]" [提供程序]
如:
dotnet ef dbcontext scaffold "server=localhost;database=efcore;uid=sa;pwd=Qwe123456;" Microsoft.EntityFrameworkCore.SqlServer
4 命令参数
4.1 生成指定表(--table)
上述命令,会生成整个数据库的表,如果需要指定特定的表,需要使用如下:
dotnet ef dbcontext scaffold "[数据库连接串]" [提供程序] --table table_name1 --table table_name2
4.2 保留数据库名称(--use-database-names)
默认情况会修正表/列名,使用该参数尽量保留原名称。
-UseDatabaseNames #PMC --use-database-names #.NET Core CLI
4.3 Fluent API 和数据注释(--data-annotations)
默认情况下,使用 Fluent API 配置实体类型。使用下面的命令,可以改为使用数据注释。
-DataAnnotations #PMC --data-annotations #.NET Core CLI
Fluent API
entity.Property(e => e.Title) .IsRequired() .HasMaxLength(160);
数据注释
[Required] [StringLength(160)] public string Title { get; set; }
4.4 指定 DbContext 名称(--context)
指定将生成的 DbContext 类的名称
-Context #PMC --context #.NET Core CLI
4.5 指定保存目录(--context-dir 和 --output-dir)
-ContextDir Data -OutputDir Models #PMC --context-dir Data --output-dir Models #.NET Core CLI
4.6 指定命名空间(--namespace 和 --context-namespace)
-Namespace Your.Namespace -ContextNamespace Your.DbContext.Namespace #PMC --namespace Your.Namespace --context-namespace Your.DbContext.Namespace #.NET Core CLI
5 测试
5.1 新建一个控制台程序
这里命名为:DbFirstTest
5.2 引入 Nuget 包
# 引入 EF Core 核心包 dotnet add package Microsoft.EntityFrameworkCore.Design -v 6.0.4 # 引入 SQL Server 提供程序 dotnet add package Microsoft.EntityFrameworkCore.SqlServer -v 6.0.4
5.3 执行 Scaffold 命令
在执行 Scaffold 命令前,如果使用 vs 打开 shell 一般是在解决方案的目录下,需要先 cd 进入项目目录:
# 如下,我的解决方案目录为:PS D:\_code\testnetcore\EFCoreTestApi> PS D:\_code\testnetcore\EFCoreTestApi> cd DbFirstTest PS D:\_code\testnetcore\EFCoreTestApi\DbFirstTest>
在控制台程序的根目录下,执行命令:
dotnet ef dbcontext scaffold "server=localhost;database=efcore;uid=sa;pwd=Qwe123456;" Microsoft.EntityFrameworkCore.SqlServer --data-annotations --context EfCoreContext --context-dir Data --output-dir Models
--data-annotations:数据注释在实体上
--context EfCoreContext:上下文指定命名为 EfCoreContext
--context-dir Data:上下文保存在根目录的 Data 文件夹下
--output-dir Models:实体保存在根目录的 Models 文件夹下
5.4 测试源码
在 Program.cs 添加测试代码:
EfCoreContext db = new EfCoreContext(); Test test = new Test() { Id = Guid.NewGuid(), Name = "Add" }; db.Tests.Add(test); db.SaveChanges();
在项目根目录下,执行:
dotnet build #编译 dotnet run #运行
执行以后,可以看到,数据库中添加了相应的记录。
5.5 源码
Gitee:https://gitee.com/lisheng741/testnetcore/tree/master/EFCoreTestApi/DbFirstTest
Github:https://github.com/lisheng741/testnetcore/tree/master/EFCoreTestApi/DbFirstTest
参考来源
EF Core官方文档:反向工程
这篇关于EFCore 的 DbFirst 模式的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-15PingCAP 黄东旭参与 CCF 秀湖会议,共探开源教育未来
- 2024-05-13PingCAP 戴涛:构建面向未来的金融核心系统
- 2024-05-09flutter3.x_macos桌面os实战
- 2024-05-09Rust中的并发性:Sync 和 Send Traits
- 2024-05-08使用Ollama和OpenWebUI在CPU上玩转Meta Llama3-8B
- 2024-05-08完工标准(DoD)与验收条件(AC)究竟有什么不同?
- 2024-05-084万 star 的 NocoDB 在 sealos 上一键起,轻松把数据库编程智能表格
- 2024-05-08Mac 版Stable Diffusion WebUI的安装
- 2024-05-08解锁CodeGeeX智能问答中3项独有的隐藏技能
- 2024-05-08RAG算法优化+新增代码仓库支持,CodeGeeX的@repo功能效果提升