ASP.NET Core 3.1系列(15)——EFCore之DB First

这篇具有很好参考价值的文章主要介绍了ASP.NET Core 3.1系列(15)——EFCore之DB First。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1、前言

本文开始介绍一些关于Entity Framework Core的内容。在EFCore中,常用的为DB First模式和Code First模式,下面就来介绍一下如何在EFCore中使用DB First模式生成实体类和数据库上下文。

2、创建测试数据库

SQL Server中新建一个数据库Dao,执行如下语句,创建CountryProvince数据表。

USE [Dao]
GO

/****** Object:  Table [dbo].[Country]    Script Date: 2022/11/30 8:52:23 ******/
SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

CREATE TABLE [dbo].[Country](
	[Id] [int] IDENTITY(1,1) NOT NULL,
	[CountryName] [nvarchar](20) NULL,
 CONSTRAINT [PK_Country] 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]
GO
USE [Dao]
GO

/****** Object:  Table [dbo].[Province]    Script Date: 2022/11/30 8:53:00 ******/
SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

CREATE TABLE [dbo].[Province](
	[Id] [int] IDENTITY(1,1) NOT NULL,
	[ProvinceName] [nvarchar](20) NULL,
 CONSTRAINT [PK_Province] 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]
GO

运行结果如下图所示:

ASP.NET Core 3.1系列(15)——EFCore之DB First,ASP.NET Core,C#,数据库,asp.net,microsoft

3、引入EFCore相关组件

创建一个Web API项目,使用NuGet引入如下四个组件,这里全部选择3.1.31版本:

Microsoft.EntityFrameworkCore
Microsoft.EntityFrameworkCore.SqlServer
Microsoft.EntityFrameworkCore.Design
Microsoft.EntityFrameworkCore.Tools

ASP.NET Core 3.1系列(15)——EFCore之DB First,ASP.NET Core,C#,数据库,asp.net,microsoft

4、生成实体类和数据库上下文

EFCore中,使用DB First模式生成实体类和数据库上下文时需要使用Scaffold-DbContext命令,该命令的格式如下所示:

Scaffold-DbContext [-Connection] <String> [-Provider] <String> [-OutputDir <String>] [-ContextDir <String>] [-Context <String>] [-Schemas <String[]>] [-Tables <String[]>] [-DataAnnotations] [-UseDatabaseNames] [-Force] [-Project <String>] [-StartupProject <String>][<CommonParameters>]

Scaffold-DbContext命令中的参数说明如下表所示:

名称 含义
-Connection 指定数据库的连接字符串
-Provider 指定要使用的提供程序。例如Microsoft.EntityFrameworkCore.SqlServer
-OutputDir 指定用于输出类的目录。如果省略,则使用顶级项目目录
-ContextDir 指定存放DbContext的目录
-Context 指定生成的DbContext类的名称
-Schemas 指定要为其生成类的模式
-Tables 指定要为其生成类的表
-DataAnnotations 使用DataAnnotation属性在可能的情况下配置模型
-Force 强制脚手架覆盖现有文件
-Project 指定实体类和数据库上下文存放在的项目名称
-StartupProject 指定启动项目名称

打开NuGet控制台,输入如下命令:

Scaffold-DbContext -Connection "Data Source=DSF-PC;Initial Catalog=Dao;User ID=sa;Password=123456;" -Provider Microsoft.EntityFrameworkCore.SqlServer -OutputDir Models -ContextDir Context -Context DaoDbContext

运行结果如下图所示,可以发现已经创建了实体类CountryProvince和数据库上下文类DaoDbContext。到此为止,我们已经可以通过Scaffold-DbContext命令生成实体类和数据库上下文了。

ASP.NET Core 3.1系列(15)——EFCore之DB First,ASP.NET Core,C#,数据库,asp.net,microsoft

5、Scaffold-DbContext命令中一些参数的含义及作用

在上面的代码中,我们对Scaffold-DbContext命令中的一些关键参数进行了设置:

  • -OutputDir Models:存放实体类的文件夹名称为Models
  • -ContextDir Context:存放数据库上下文的文件夹名称为Context
  • -Context DaoDbContext:数据库上下文的名称为DaoDbContext

其实Scaffold-DbContext命令中还包括一些很有用的其他参数,下面举例说明。

5.1、只对数据库中的某些表生成实体类该怎么做?

在某些情况下,我们并不希望数据库中所有的表都生成实体类,而是只将某些需要的表生成实体类即可,此时就需要对-Tables参数进行设置,下面的代码只对Country表生成实体类,而Province表则不生成实体类。

Scaffold-DbContext -Connection "Data Source=DSF-PC;Initial Catalog=Dao;User ID=sa;Password=123456;" -Provider Microsoft.EntityFrameworkCore.SqlServer -OutputDir Models -ContextDir Context -Context DaoDbContext -Tables "Country"

ASP.NET Core 3.1系列(15)——EFCore之DB First,ASP.NET Core,C#,数据库,asp.net,microsoft

5.2、如何生成实体类字段的数据注解?

当前的实体类字段并不包含数据注解,如下图所示:

ASP.NET Core 3.1系列(15)——EFCore之DB First,ASP.NET Core,C#,数据库,asp.net,microsoft
ASP.NET Core 3.1系列(15)——EFCore之DB First,ASP.NET Core,C#,数据库,asp.net,microsoft
如果需要生成数据注解,只需要添加一个-DataAnnotations参数即可,代码如下:

Scaffold-DbContext -Connection "Data Source=DSF-PC;Initial Catalog=Dao;User ID=sa;Password=123456;" -Provider Microsoft.EntityFrameworkCore.SqlServer -OutputDir Models -ContextDir Context -Context DaoDbContext -DataAnnotations

可以发现实体类字段已经生成了对应的数据注解。

ASP.NET Core 3.1系列(15)——EFCore之DB First,ASP.NET Core,C#,数据库,asp.net,microsoft
ASP.NET Core 3.1系列(15)——EFCore之DB First,ASP.NET Core,C#,数据库,asp.net,microsoft

5.3、数据库被修改后如何更新实体类和数据库上下文?

当前工程中的实体类和数据库上下文如下图所示:

ASP.NET Core 3.1系列(15)——EFCore之DB First,ASP.NET Core,C#,数据库,asp.net,microsoft
下面对数据库进行一些修改。首先在Dao数据库中新增一张City表,代码如下:

USE [Dao]
GO

/****** Object:  Table [dbo].[City]    Script Date: 2022/11/30 9:30:54 ******/
SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

CREATE TABLE [dbo].[City](
	[Id] [int] IDENTITY(1,1) NOT NULL,
	[CityName] [nvarchar](20) NULL,
	[CreateTime] [datetime] NULL,
 CONSTRAINT [PK_City] 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]
GO

ASP.NET Core 3.1系列(15)——EFCore之DB First,ASP.NET Core,C#,数据库,asp.net,microsoft
然后在Country表和Province表中新增一个字段CreateTime,代码如下:

alter table Country add [CreateTime] datetime null
alter table Province add [CreateTime] datetime null

ASP.NET Core 3.1系列(15)——EFCore之DB First,ASP.NET Core,C#,数据库,asp.net,microsoft
现在对数据库的修改已经完成,下面就需要对实体类和数据库上下文进行更新了,我们只需要在Scaffold-DbContext命令后面加上-Force参数即可,它可以帮助我们重新生成实体类和数据库上下文并覆盖原有文件。

Scaffold-DbContext -Connection "Data Source=DSF-PC;Initial Catalog=Dao;User ID=sa;Password=123456;" -Provider Microsoft.EntityFrameworkCore.SqlServer -OutputDir Models -ContextDir Context -Context DaoDbContext -DataAnnotations -Force

可以发现覆盖后的文件已经新增了City实体类,CountryProvince实体类也都新增了CreateTime字段。

ASP.NET Core 3.1系列(15)——EFCore之DB First,ASP.NET Core,C#,数据库,asp.net,microsoft
ASP.NET Core 3.1系列(15)——EFCore之DB First,ASP.NET Core,C#,数据库,asp.net,microsoft
ASP.NET Core 3.1系列(15)——EFCore之DB First,ASP.NET Core,C#,数据库,asp.net,microsoft

5.4、分层项目中如何在其他类库中生成实体类和数据库上下文?

在实际开发过程中,很多项目都会进行分层操作,例如新建一个App.Models类库用来存放实体类和数据库上下文,如下图所示:

ASP.NET Core 3.1系列(15)——EFCore之DB First,ASP.NET Core,C#,数据库,asp.net,microsoft
如果想在App.Models类库中生成实体类和数据库上下文也很简单,只需要按照如下步骤操作即可,首先在App.Models中使用NuGet引入EFCore的相关组件,如下所示:

Microsoft.EntityFrameworkCore
Microsoft.EntityFrameworkCore.SqlServer
Microsoft.EntityFrameworkCore.Design
Microsoft.EntityFrameworkCore.Tools

然后生成一下解决方案:

ASP.NET Core 3.1系列(15)——EFCore之DB First,ASP.NET Core,C#,数据库,asp.net,microsoft
最后在Scaffold-DbContext命令中设置-Project-StartupProject参数,代码如下:

Scaffold-DbContext -Connection "Data Source=DSF-PC;Initial Catalog=Dao;User ID=sa;Password=123456;" -Provider Microsoft.EntityFrameworkCore.SqlServer -OutputDir Models -ContextDir Context -Context DaoDbContext -DataAnnotations -Force -Project App.Models -StartupProject App.Models

可以发现在App.Models项目中已经生成了实体类和数据库上下文。

ASP.NET Core 3.1系列(15)——EFCore之DB First,ASP.NET Core,C#,数据库,asp.net,microsoft

6、注入数据库上下文

现在实体类和数据库上下文都有了,接下来只需要在Controller中将其注入即可。首先在appsettings.json文件中配置数据库连接字符串,代码如下:

{
    "Logging": {
        "LogLevel": {
            "Default": "Information",
            "Microsoft": "Warning",
            "Microsoft.Hosting.Lifetime": "Information"
        }
    },
    "AllowedHosts": "*",
    "ConnectionStrings": {
        "ConnectionString": "Data Source=DSF-PC;Initial Catalog=Dao;User ID=sa;Password=123456;"
    }
}

然后在Startup.cs文件中添加数据库上下文,代码如下所示:

using App.Context;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;

namespace App
{
    public class Startup
    {
        public Startup(IConfiguration configuration)
        {
            Configuration = configuration;
        }

        public IConfiguration Configuration { get; }

        // This method gets called by the runtime. Use this method to add services to the container.
        public void ConfigureServices(IServiceCollection services)
        {
            // 添加控制器
            services.AddControllers();

            // 添加数据库上下文
            services.AddDbContext<DaoDbContext>(options =>
            {
                options.UseSqlServer(Configuration.GetConnectionString("ConnectionString"));
            });
        }

        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
        {
            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
            }
            app.UseHttpsRedirection();
            app.UseRouting();
            app.UseAuthorization();
            app.UseEndpoints(endpoints =>
            {
                endpoints.MapControllers();
            });
        }
    }
}

最后新建一个控制器CountryController.cs,将DaoDbContext注入即可,代码如下:

using App.Context;
using App.Models;
using Microsoft.AspNetCore.Mvc;
using System.Collections.Generic;
using System.Linq;

namespace App.Controllers
{
    [Route("api/[controller]/[action]")]
    [ApiController]
    public class CountryController : ControllerBase
    {
        protected readonly DaoDbContext _dbContext;

        /// <summary>
        /// 构造函数
        /// </summary>
        /// <param name="dbContext"></param>
        public CountryController(DaoDbContext dbContext)
        {
            _dbContext = dbContext;
        }

        /// <summary>
        /// 添加实体集合
        /// </summary>
        /// <returns></returns>
        [HttpGet]
        public ActionResult<string> Add()
        {
            List<Country> list = new List<Country>
            {
                new Country { CountryName = "中国" },
                new Country { CountryName = "美国" },
                new Country { CountryName = "俄罗斯" }
            };
            _dbContext.Set<Country>().AddRange(list);
            _dbContext.SaveChanges();
            return "添加实体成功";
        }

        /// <summary>
        /// 获取实体集合
        /// </summary>
        /// <returns></returns>
        [HttpGet]
        public ActionResult<List<Country>> Get()
        {
            return _dbContext.Set<Country>().ToList();
        }
    }
}

执行Add方法后,运行结果如下图所示:

ASP.NET Core 3.1系列(15)——EFCore之DB First,ASP.NET Core,C#,数据库,asp.net,microsoft
执行Get方法后,运行结果如下图所示:

ASP.NET Core 3.1系列(15)——EFCore之DB First,ASP.NET Core,C#,数据库,asp.net,microsoft

7、结语

本文主要介绍了一些关于EFCoreDB First开发模式的内容,对于Scaffold-DbContext命令中其他的参数含义及作用,有兴趣的同志也可以自行深入研究。如果你参与的项目之前就已经存在数据库,那么选用DB First模式可能会更加方便友好。文章来源地址https://www.toymoban.com/news/detail-552935.html

到了这里,关于ASP.NET Core 3.1系列(15)——EFCore之DB First的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • asp.net core EFCore 属性配置与DbContext

    Entity Framework (EF) Core 是轻量化、可扩展、开源和跨平台版的常用 Entity Framework 数据访问技术。用于程序中的class类和数据库中的表互相之间建立映射关系。在学习过程中,EFCore中的属性配置显的尤为重要它是学习好asp.net core的基础是配置数据库表结构的重要基石。本篇内容为

    2024年02月07日
    浏览(63)
  • .NET6.0 EF Core 之 DB First生成实体类

    EF Core可以使用DB First模式生成实体类具体步骤如下: 因为.NET Core中默认不包含EF Core的工具和程序包,需要通过NuGet管理器安装对应的工具和程序包,这里使用SQL Server数据库。 Microsoft.EntityFrameworkCore.SqlServer:SQL Server数据库EF提供程序 Microsoft.EntityFrameworkCore.Design:设计时使用到

    2024年02月06日
    浏览(50)
  • asp.net core 6.0 efcore +sqlserver增删改查的demo

    下面是一个使用ASP.NET Core 5.0和Entity Framework Core进行增删改查操作的示例。 首先,创建一个空的ASP.NET Core 6.0 Web应用程序项目。 然后,安装以下NuGet包: Microsoft.EntityFrameworkCore.SqlServer Microsoft.EntityFrameworkCore.Tools 接下来,创建一个数据库上下文类,用于定义实体类和数据库连接

    2024年02月13日
    浏览(44)
  • ASP.Net Core Web Api+EFCore+MySql实现动态查询(保姆教学)

    本文会详细讲解如何从打开文件到第一个API开发完成,过程十分详细,是基于学习入门。 现在让我们开始吧! 打开VS(演示用的Visual Studio2022) 第一步我们选择创建新项目   第二步 选择开发语言以及应用程序 我们选择C# -所有平台-Web API.找到 ASP.NET Core Web API 应用   这里应用

    2024年02月12日
    浏览(43)
  • .NET6 + EF Core + MySQL 创建实体和数据库、EFCore 数据迁移

    接上期文章《.NET6项目连接数据库方式方法》,有人问了我几个问题,现在就这几个问题,拓展延申一下创建实体类、数据库。把ORM框架和数据迁移都写进去。 我的项目是在Linux上创建的,使用的是vscode开发工具远程开发。为了方便大家阅读和操作,我将项目down到我的本地电

    2024年02月05日
    浏览(51)
  • Asp.net Core系列学习(1)

    ASP.NET Core 是一个跨平台的高性能开源 框架 ,用于生成启用云且连接 Internet 的新式应用。 使用 ASP.NET Core,可以: 生成 Web 应用和服务、物联网 (IoT) 应用和移动后端。 在 Windows、macOS 和 Linux 上使用喜爱的开发工具。 部署到云或本地。 在 .NET Core 上运行。 ASP.NET Core 是对 ASP

    2024年02月06日
    浏览(66)
  • ASP.NET Core 配置系列一

    A S P . N E T   C o r e   配 置 主 要 通 过 这 3 个 文 件 设 置 : 1   项 目 文 件 也 叫 . c s p r o j   文 件 2   P r o g r a m . c s 3   a p p s e t t i n g s . j s o n 这 些 配 置 告 诉 A S P . N E T   C o r e   应 用 程 序 基 于 用 户 的 交 互 是 如 何 工 作 的, 在 本 节 中 我 们 理 解 A S P .

    2024年02月03日
    浏览(108)
  • ASP.NET Core 依赖注入系列一

    什么是ASP.NET Core 依赖注入? 依赖注入也称DI是一项技术用来实现对象松耦合以至于应用程序更容易维护,ASP.NET Core通过控制器的构造函数自动注入依赖的对象,我们创建ASP.NET Core MVC应用程序演示依赖注入特性是如何工作, 在这节中我们讲解该特性 1 例子 我们创建一个ASP.NET C

    2024年02月11日
    浏览(53)
  • ASP.NET Core MVC 从入门到精通之数据库

    随着技术的发展,ASP.NET Core MVC也推出了好长时间,经过不断的版本更新迭代,已经越来越完善,本系列文章主要讲解ASP.NET Core MVC开发B/S系统过程中所涉及到的相关内容,适用于初学者,在校毕业生,或其他想从事ASP.NET Core MVC 系统开发的人员。 经过前几篇文章的讲解,初步

    2023年04月27日
    浏览(90)
  • ASP.NET Core SignalR 系列(二)- 中心(服务端)

    本章将和大家分享 ASP.NET Core SignalR 中的中心(服务端)。 本文大部分内容摘自微软官网:https://learn.microsoft.com/zh-cn/aspnet/core/signalr/hubs?view=aspnetcore-7.0 废话不多说,我们直接来看一个Demo,Demo的目录结构如下所示: 本Demo的Web项目为ASP.NET Core Web 应用程序( 目标框架为.NET 7.0

    2024年02月13日
    浏览(53)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包