7.3EF Core与ASP.NET Core集成

简介: 7.3EF Core与ASP.NET Core集成

7.3EF Core与ASP.NET Core集成

案例:

  1. Nuget安装Microsoft.EntityFrameworkCore.Relational、Microsoft.EntityFrameworkCore.Sqlite、Microsoft.EntityFrameworkCore.Tools
  2. 定义Book实体类

publicrecordBook

{

   publicGuidId { get; set; }

   publicstringName { get; set; }

   publicdoublePrice { get; set; }

}

  1. 定义Book配置类

publicclassBookConfig : IEntityTypeConfiguration<Book>

{

   publicvoidConfigure(EntityTypeBuilder<Book>builder)

   {

       builder.ToTable("Books");

   }

}

  1. 增加上下文类

publicclassMyDbContext:DbContext

{

   publicDbSet<Book>Books { get; set; }

   //与之前编写的上下文类不同,之前上下文类会重写OnConfiguring方法,并在里面设置连接字符串

   //但现在要求连接字符串要放在配置中

   //后面会在Program.cs中用依赖注入的方式使用MyDbContext,所以在这里加了一个构造函数

   publicMyDbContext(DbContextOptions<MyDbContext>options) : base(options)

   {

   }

   protectedoverridevoidOnModelCreating(ModelBuildermodelBuilder)

   {

       base.OnModelCreating(modelBuilder);

       //设置需要加载的程序集

       //加载当前程序集中所有实现了IEntityTypeConfiguration接口的类

       modelBuilder.ApplyConfigurationsFromAssembly(this.GetType().Assembly);

   }

}

  1. 在appsettings.json中增加数据库连接字符的设置

"ConnectionStrings": { "Default": "Data Source=MySqLite.db" }

  1. 在Program.cs中使用依赖注入的方式对上下文的连接字符进行配置

builder.Services.AddDbContext<MyDbContext>(opt=> {

   stringconstr=builder.Configuration.GetConnectionString("Default");

   opt.UseSqlite(constr);

});

//如果有多个数据库需要配置,可以直接在后面加,因为AddDbContext是泛型的

  1. 增加控制类

[Route("[controller]/[action]")]

publicclassTestController : ControllerBase

{

   privatereadonlyMyDbContextdbCtx;

   publicTestController(MyDbContextdbCtx)

   {

       this.dbCtx=dbCtx;

   }

   [HttpPost]

   publicasyncTask<IActionResult>Index()

   {

       dbCtx.Add(newBook { Id=Guid.NewGuid(), Name="ddd", Price=40 });

       awaitdbCtx.SaveChangesAsync();

       varbook=dbCtx.Books.First();

       returnContent(book.ToString());

   }

}

  1. 如果在多项目环境下执行Add-Migration迁移命令的时候,迁移工具发生报错。此时可以使用IDesignTimeDbContextFactory接口来解决。当项目中存在一个该接口的时候,迁移工具会调用实现接口类的CreateDbContext方法来获取上下文对象,然后迁移工具使用这个上下文来连接数据库。

//该代码只有在开发环境下才会运行

classMyDesignTimeDbContextFactory:IDesignTimeDbContextFactory<MyDbContext>

{

   publicMyDbContextCreateDbContext(string[] args)

   {

       DbContextOptionsBuilder<MyDbContext>builder=new();

       //定义了环境变量,其实可以直接使用字符串

       stringconnStr=Environment.GetEnvironmentVariable("ConnectionStrings:BooksEFCore");

       builder.UseSqlServer(connStr);

       returnnewMyDbContext(builder.Options);

   }

}

  1. 使用Add-Migration Init、Update-database等命令完成数据库的创建

上下文池

上下文被创建的时候,要执行实体类的配置,所以会消耗较多的资源,所以EF Core提供了AddDbContextPool来注入上下文,对于使用了AddDbContextPool注入的上下文,EF Core会优先从上下文池中获取实例。但是,因为池中的上下文实例会被反复使用,因此没有办法为上下文注入服务。

在项目开发时,建议使用“小上下文”策略,不要把项目中所有的实体放到一个上下文中,而是要将关联性大的实体放到一个上下文中。

如果采用“小上下文”策略,则需要手动注册所有的上下文,批量注册上下文的方法:

publicstaticIServiceCollectionAddAllDbContexts(thisIServiceCollectionservices, Action<DbContextOptionsBuilder>builder, IEnumerable<Assembly>assemblies)

{

   Type[] types=newType[] { typeof(IServiceCollection), typeof(Action<DbContextOptionsBuilder>), typeof(ServiceLifetime), typeof(ServiceLifetime) };

   //通过反射获取AddDbContext方法,1代表只有1个泛型参数

   varmethodAddDbContext=typeof(EntityFrameworkServiceCollectionExtensions).GetMethod("AddDbContext",1,types);

   foreach (varasmToLoadinassemblies)

   {

       //获取非抽象的上下文类

       foreach (vardbCtxTypeinasmToLoad.GetTypes().Where(t=>!t.IsAbstract&&typeof(DbContext).IsAssignableFrom(t)))

       {

           //由于AddDbContext是泛型方法,所以先设定泛型

           varmethodGenericAddDbContext=methodAddDbContext.MakeGenericMethod(dbCtxType);

           methodGenericAddDbContext.Invoke(null, newobject[] { services, builder, ServiceLifetime.Scoped, ServiceLifetime.Scoped });

       }

   }

   returnservices;

}

相关文章
|
4月前
|
开发框架 .NET C#
ASP.NET Core Blazor 路由配置和导航
大家好,我是码农刚子。本文系统介绍Blazor单页应用的路由机制,涵盖基础配置、路由参数、编程式导航及高级功能。通过@page指令定义路由,支持参数约束、可选参数与通配符捕获,结合NavigationManager实现页面跳转与参数传递,并演示用户管理、产品展示等典型场景,全面掌握Blazor路由从入门到实战的完整方案。
387 6
|
开发框架 .NET 开发者
简化 ASP.NET Core 依赖注入(DI)注册-Scrutor
Scrutor 是一个简化 ASP.NET Core 应用程序中依赖注入(DI)注册过程的开源库,支持自动扫描和注册服务。通过简单的配置,开发者可以轻松地从指定程序集中筛选、注册服务,并设置其生命周期,同时支持服务装饰等高级功能。适用于大型项目,提高代码的可维护性和简洁性。仓库地址:&lt;https://github.com/khellang/Scrutor&gt;
382 5
|
开发框架 算法 中间件
ASP.NET Core 中的速率限制中间件
在ASP.NET Core中,速率限制中间件用于控制客户端请求速率,防止服务器过载并提高安全性。通过`AddRateLimiter`注册服务,并配置不同策略如固定窗口、滑动窗口、令牌桶和并发限制。这些策略可在全局、控制器或动作级别应用,支持自定义响应处理。使用中间件`UseRateLimiter`启用限流功能,并可通过属性禁用特定控制器或动作的限流。这有助于有效保护API免受滥用和过载。 欢迎关注我的公众号:Net分享 (239字符)
330 1
|
开发框架 缓存 .NET
GraphQL 与 ASP.NET Core 集成:从入门到精通
本文详细介绍了如何在ASP.NET Core中集成GraphQL,包括安装必要的NuGet包、创建GraphQL Schema、配置GraphQL服务等步骤。同时,文章还探讨了常见问题及其解决方法,如处理复杂查询、错误处理、性能优化和实现认证授权等,旨在帮助开发者构建灵活且高效的API。
395 3
|
开发框架 前端开发 .NET
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
490 0
|
开发框架 前端开发 JavaScript
ASP.NET MVC 教程
ASP.NET 是一个使用 HTML、CSS、JavaScript 和服务器脚本创建网页和网站的开发框架。
279 7
|
存储 开发框架 前端开发
[回馈]ASP.NET Core MVC开发实战之商城系统(五)
经过一段时间的准备,新的一期【ASP.NET Core MVC开发实战之商城系统】已经开始,在之前的文章中,讲解了商城系统的整体功能设计,页面布局设计,环境搭建,系统配置,及首页【商品类型,banner条,友情链接,降价促销,新品爆款】,商品列表页面,商品详情等功能的开发,今天继续讲解购物车功能开发,仅供学习分享使用,如有不足之处,还请指正。
394 0
|
开发框架 前端开发 .NET
[回馈]ASP.NET Core MVC开发实战之商城系统(一)
[回馈]ASP.NET Core MVC开发实战之商城系统(一)
511 0
|
SQL 开发框架 前端开发
[回馈]ASP.NET Core MVC开发实战之商城系统(开篇)
[回馈]ASP.NET Core MVC开发实战之商城系统(开篇)
474 0
|
存储 开发框架 前端开发
ASP.NET MVC 迅速集成 SignalR
ASP.NET MVC 迅速集成 SignalR
306 0