日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

浅谈 EF CORE 迁移和实例化的几种方式

發布時間:2023/12/4 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 浅谈 EF CORE 迁移和实例化的几种方式 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

出于學習和測試的簡單需要,使用 Console 來作為 EF CORE 的承載程序是最合適不過的。今天筆者就將平時的幾種使用方式總結成文,以供參考,同時也是給本人一個溫故知新的機會。因為沒有一個完整的脈絡,所以也只是想起什么寫點什么,不通順的地方還請多多諒解。

本文對象數據庫默認為 VS 自帶的 LocalDB

1. Normal & Simple

先介紹一種最簡單的構建方式,人人都會。

  • 新建 Console 應用程序,命名自定

  • 安裝相關Nuget 包

//Sql Server Database ProviderInstall-Package Microsoft.EntityFrameworkCore.SqlServer//提供熟悉的Add-MigrationUpdate-Database等Powershell命令,不區分關系型數據庫類型Install-Package Microsoft.EntityFrameworkCore.Tools
  • 自定義 DbContext

public class MyContext:DbContext{ ? ?protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) ? ?{optionsBuilder.UseSqlServer("Server=(localdb)\\mssqllocaldb;Database=ConsoleApp;Trusted_Connection=True;MultipleActiveResultSets=true;");} }
  • 執行遷移和更新命令

Add-Migration InitializeUpdate-Database
  • 使用方式

using (var context = new MyContext()) { ? ?// TODO}

剛以上,我們便見識到了了一種最平常也是最簡單的使用方式,接下來,讓我們用其他方式去慢慢地改造它,從而盡可能地接觸更多的用法。

2. Level Up

2.1 準備工作

將第一步生成的數據庫,遷移文件和使用方式內容全部刪除。

2.2 更新 MyContext 內容

刪除 MyContext 中的 OnConfiguring 方法及其內容,增加含有 DbContextOptions 類型參數的構造器,我們的MyContext看起來應該是下面這個樣子。

public class MyContext : DbContext{ ? ?public MyContext(DbContextOptions options) : base(options) ? ?{} }

假如我們此時仍然再執行遷移命令,VS將提示以下錯誤

No parameterless constructor was found on 'MyContext'. Either add a parameterless constructor to 'MyContext' or add an implementation of 'IDbContextFactory ' in the same assembly as 'MyContext'.

添加無參構造器的方式之后再講解,先來按照提示信息添加一個 IDbContextFactory 的實現類。

public class MyContextFactory : IDbContextFactory<MyContext> { ? ?public MyContext Create(DbContextFactoryOptions options) ? ?{var optionsBuilder = new DbContextOptionsBuilder<MyContext>();optionsBuilder.UseSqlServer("Server=(localdb)\\mssqllocaldb;Database=ConsoleApp;Trusted_Connection=True;MultipleActiveResultSets=true;"); ? ? ? ? ? ?return new MyContext(optionsBuilder.Options);} }

之后再次運行遷移和更新數據庫的命令也是水到渠成。

2.3 使用方式:構造器實例化

既然 MyContext 含有 DbContextOptions 類型參數的構造器,那就手動創建一個參數實例注入即可。

var contextOptionsBuilder = new DbContextOptionsBuilder<MyContext>(); contextOptionsBuilder.UseSqlServer("Server=(localdb)\\mssqllocaldb;Database=ConsoleApp;Trusted_Connection=True;MultipleActiveResultSets=true;");// 注入配置選項using (var context = new MyContext(contextOptionsBuilder.Options)) { ? ?// TODO}

經此,我們知道了遷移命令會檢測 Context 的相關配置入口,只有在滿足存在 OnConfiguring 方法或者存在自建 IDbContextFactory 實現類的情況下,命令才能成功運行。

3. Day Day Up

目前為止,我們已經知道如何手動遷移和實例化 Context 的步驟了所以讓我們更進一步。寫過 ASP.NET CORE 的人可能知道在 ASP.NET CORE 中,Context 常常以依賴注入的方式引入到我們的 Web 層,Service 層,或者 XXCore 層中(話說筆者最近最喜歡的解決方案開發架構就是偽 DDD 的四層架構,有空再介紹吧)。其實在 Console 應用中,這也可以很容易實現,具體的依賴注入引入可以參考筆者的上一篇博客,所以最終的代碼效果如下:

var serviceCollection = new ServiceCollection(); serviceCollection.AddDbContext<MyContext>(c => { ? ?c.UseSqlServer("Server=(localdb)\\mssqllocaldb;Database=ConsoleApp;Trusted_Connection=True;MultipleActiveResultSets=true;"); });var serviceProvider = serviceCollection.BuildServiceProvider();using (var context = serviceProvider.GetService<MyContext>()) { ? ?//context.Database.Migrate();}

至此,我們便基本完成了本文的主題,唯一有些美中不足的是我們的數據庫連接字符串好像到處都是,這不是什么大問題,筆者直接將 Configuration 的配置代碼貼在下面,這也是 ABP 中的方式。

public class AppConfigurations{ ?
?private static readonly ConcurrentDictionary<string, IConfigurationRoot> ConfigurationCache; ?
?
??static AppConfigurations() ? ?{ConfigurationCache = new ConcurrentDictionary<string, IConfigurationRoot>();} ? ?public static IConfigurationRoot Get(string environmentName = null) ? ?{ ? ? ? ?var cacheKey = "#" + environmentName; ? ? ?
?? ?return ConfigurationCache.GetOrAdd(cacheKey,_ => BuildConfiguration(environmentName));} ?
??
???private static IConfigurationRoot BuildConfiguration(string environmentName = null) ? ?{ ? ? ? ?var builder = new ConfigurationBuilder().SetBasePath(Directory.GetCurrentDirectory()).AddJsonFile("appsettings.json", true, true); ? ?
???? ?if (!string.IsNullOrWhiteSpace(environmentName))builder = builder.AddJsonFile($"appsettings.{environmentName}.json", true);builder = builder.AddEnvironmentVariables(); ? ?
??? ? ?return builder.Build();} }

這個工具類的使用方式就不再贅述了。

4. 結尾

最后,想必會有人問為什么要折騰這樣一個小小的 Console 應用呢?其實通過這樣一步步下來,我們可以發現一些項目功能上的亮點,比如既然可以自配置 DbContext 的 Option 選項,同時我們也知道了如何在類庫和 Console 項目中添加依賴注入以及 Configuration 提取鏈接參數的功能,那針對三層架構或是 DDD 項目增加含真實數據庫或是內存數據庫(InMemory)的單元測試,或者是自動Migrate Context 和更新數據庫也將是十分簡單的一件事,至少看起來會比官方的示例更加真實和具有可操作性。而這部分內容筆者也將會在之后的博文中給出。

相關文章:?

  • Entity Framework Core 生成跟蹤列

  • 在Apworks數據服務中使用基于Entity Framework Core的倉儲(Repository)實現

  • Entity Framework Core的貼心:優雅處理帶默認值的數據庫字段

  • Entity Framework Core 實現MySQL 的TimeStamp/RowVersion 并發控制

  • Entity Framework Core 軟刪除與查詢過濾器

  • Entity Framework Core 命名約定

  • 全文索引 - Pomelo.EFCore.MySql

  • Entity Framework Core 批處理語句

原文地址:http://www.cnblogs.com/Wddpct/p/7249670.html


.NET社區新聞,深度好文,微信中搜索dotNET跨平臺或掃描二維碼關注

總結

以上是生活随笔為你收集整理的浅谈 EF CORE 迁移和实例化的几种方式的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。