翼度科技»论坛 编程开发 .net 查看内容

.NET 6 Entity Framework Core Db First(1) 创建模型

8

主题

8

帖子

24

积分

新手上路

Rank: 1

积分
24
项目准备

1、开发环境

  vs2022  .NET6
2、创建项目


  • 新建项目 ASP.NET Core Web API,解决方案名称:EFDBFirstDemo,项目名称:EFDBFirstDemo.API,选择.NET 6.0
  • 解决方案=》新建项目=》类库,类库名称:EFDBFirstDemo.Model,选择.NET 6.0
安装 EF Core

安装方式


  • 使用程序包管理控制台。打开方式:工具=》NuGet包管理器=》程序包管理控制台。使用方法:https://learn.microsoft.com/zh-cn/nuget/consume-packages/install-use-packages-powershell
  • 通过右键单击项目并选择“管理 NuGet 程序包”来安装包
NuGet 程序包


  • Microsoft.EntityFrameworkCore.Tools
    安装 PMC 工具,执行设计时开发任务。 例如,可以创建迁移、应用迁移,并为基于现有数据库的模型生成代码。
    参考:https://learn.microsoft.com/zh-cn/ef/core/cli/powershell
    Install-Package Microsoft.EntityFrameworkCore.Tools -Version 6.0.27

  • Microsoft.EntityFrameworkCore.Design
    生成数据库实体、上下文,这个注意需要安装到启动项目(EFDBFirstDemo.API)
    Install-Package Microsoft.EntityFrameworkCore.Design -Version 6.0.27

  • Microsoft.AspNetCore.Diagnostics.EntityFrameworkCore
    提供 EF Core 错误页的 ASP.NET Core 中间件。 此中间件有助于检测和诊断 EF Core 迁移错误。
    Install-Package Microsoft.AspNetCore.Diagnostics.EntityFrameworkCore -Version 6.0.27

  • Microsoft.EntityFrameworkCore.SqlServer
    我这里使用的SQL server数据库,安装 Microsoft.EntityFrameworkCore.SqlServer NuGet程序包,
    如果你使用其他数据库可参考:https://learn.microsoft.com/zh-cn/ef/core/providers/?tabs=dotnet-core-cli
    Install-Package Microsoft.EntityFrameworkCore.SqlServer -Version 6.0.27

  • 安装完成
  

创建模型

1、数据库连接字符串

  在appsettings.Development.json 配置
  1. {
  2.   "ConnectionStrings": {
  3.     "demo": "Data Source=.;User Id=sa;Password=123456;database=demo;"
  4.   }
  5. }
复制代码
2、生成实体、上下文


  • EFDBFirstDemo.API项目 添加引用 EFDBFirstDemo.API项目
  • 执行命令,更多参数可查看:https://learn.microsoft.com/zh-cn/ef/core/cli/powershell
  1. Scaffold-DbContext 'Name=ConnectionStrings:demo' Microsoft.EntityFrameworkCore.SqlServer -OutputDir Models -ContextDir Context -Context DemoContext
复制代码

 

来源:https://www.cnblogs.com/Zing/p/18068509
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

举报 回复 使用道具