EFCore 的 DbFirst 模式

本文档详细介绍了如何在 EFCore 中使用 DbFirst 模式,通过 CLI 命令生成数据库实体,并提供了命令参数的详细解释,包括指定表、保留数据库名称、选择 Fluent API 或数据注释等。还给出了数据库准备、创建控制台程序、引入 Nuget 包、执行 Scaffold 命令的步骤,并提供了测试源码链接。

🚀 优质资源分享 🚀

学习路线指引(点击解锁)知识定位人群定位
🧡 Python实战微信订餐小程序 🧡进阶级本课程是python flask+微信小程序的完美结合,从项目搭建到腾讯云部署上线,打造一个全栈订餐系统。
💛Python量化交易实战💛入门级手把手带你打造一个易扩展、更安全、效率更高的量化交易系统

1 前言

EF6 时代,可以通过界面操作,添加数据库实体。

EF Core 需要通过 CLI 来进行该操作,具体请参考EF Core官方文档:反向工程

2 前置条件

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 数据库准备

由于是 DbFirst,所以这里我们先创建一个数据库,名为 efcore

新建一张表 Test

CREATE TABLE [dbo].[Test](
	[Id] [uniqueidentifier] NOT NULL,
	[Name] [nvarchar](128) NULL,
 CONSTRAINT [PK_Test] PRIMARY KEY CLUSTERED 
(
	[Id] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]

5.2 新建一个控制台程序

这里命名为:DbFirstTest

mkdir DbFirstTest & cd DbFirstTest #新建文件夹DbFirstTest并切换至该目录下
dotnet new console -f net6.0       #新建.NET6.0控制台程序

5.3 引入 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.4 执行 Scaffold 命令

在控制台程序的根目录下,执行命令(连接串请自行修改成自己的):

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.5 测试源码

在 Program.cs 添加测试代码:

using DbFirstTest.Data;
using DbFirstTest.Models;

EfCoreContext db = new EfCoreContext();
Test test = new Test()
{
    Id = Guid.NewGuid(),
    Name = "Add"
};
db.Tests.Add(test);
db.SaveChanges();
Console.WriteLine("Add Successful!");

在项目根目录下,执行:

dotnet build #编译
dotnet run   #运行

执行以后,可以看到,数据库中添加了相应的记录。

5.6 源码

Gitee:https://gitee.com/lisheng741/testnetcore/tree/master/EFCore/DbFirstTest

Github:https://github.com/lisheng741/testnetcore/tree/master/EFCore/DbFirstTest

参考来源

EF Core官方文档:反向工程

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值