ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

EFCore 的 DbFirst 模式

2022-04-21 00:03:57  阅读:216  来源: 互联网

标签:Core EFCore -- 模式 context DbFirst dotnet dir CLI


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 新建一个控制台程序

这里命名为: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官方文档:反向工程

标签:Core,EFCore,--,模式,context,DbFirst,dotnet,dir,CLI
来源: https://www.cnblogs.com/clis/p/16172367.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有