Entity Framework Core配置DbContext的兩種方式

来源:https://www.cnblogs.com/boydenyol/archive/2020/05/25/12960936.html
-Advertisement-
Play Games

Entity Framework Core配置DbContext的兩種方式 ​ 使用Entity Framework 遷移過程 中遇到過一個問題,在這裡拿出來曬曬。 Unable to create an object of type 'xxxContext'. For the different ...


Entity Framework Core配置DbContext的兩種方式

​ 使用Entity Framework遷移過程中遇到過一個問題,在這裡拿出來曬曬。

Unable to create an object of type 'xxxContext'. For the different patterns supported at design time, see https://go.microsoft.com/fwlink/?linkid=851728

​ 要解決這個問題,就是我下麵要闡述的內容了。

1. DbContext的兩種配置方式

​ 我們先來看看DbContext的兩個構造函數:

protected DbContext();
public DbContext([NotNullAttribute] DbContextOptions options);

​ 還有DbContext的兩個重寫方法:

protected internal virtual void OnConfiguring(DbContextOptionsBuilder optionsBuilder);
protected internal virtual void OnModelCreating(ModelBuilder modelBuilder);

​ 根據錯誤提示,在微軟的官方文檔中,我們知道了配置DbContext有兩種方式:

  • 使用無參構造函數,必須重寫OnConfiguring()函數

    public class BloggingContext : DbContext
    {
        public DbSet<Blog> Blogs { get; set; }
        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) => optionsBuilder.UseSqlite("Data Source=blog.db");
    }
    

    這樣使用的話,應用程式可以簡單地實例化此類上下文,而無需將任何內容傳遞給構造函數:

    using (var context = new BloggingContext())
    {
      // do stuff
    }
    
  • 使用有參構造函數,無需重寫OnConfiguring()函數

    public class BloggingContext : DbContext
    {
        public BloggingContext(DbContextOptions<BloggingContext> options) : base(options)
        { }
        public DbSet<Blog> Blogs { get; set; }
    }
    

    這樣使用的話,應用程式現在可以在實例化上下文時傳遞 DbContextOptions,如下所示:

    var optionsBuilder = new DbContextOptionsBuilder<BloggingContext>();
    optionsBuilder.UseSqlite("Data Source=blog.db");
    
    using (var context = new BloggingContext(optionsBuilder.Options))
    {
      // do stuff
    }
    
2. 遷移過程中的工廠方法

​ 那麼按照官網的做法去寫的話,為什麼還會出現文章最開頭的那個錯誤呢?這裡我使用控制台和Asp.net core程式各創建了一次程式後,發現上述問題是我在使用控制台程式測試代碼時出現的,而Asp.net core程式卻沒有出現(具體的原理我還不清楚,希望各路大俠看到能幫助解答一下)。

​ 這裡說一下控制台程式出現此問題的解決辦法(微軟官方文檔):

public class BloggingContextFactory : IDesignTimeDbContextFactory<BloggingContext>
{
	public BloggingContext CreateDbContext(string[] args)
	{
		var optionsBuilder = new DbContextOptionsBuilder<BloggingContext>();
		optionsBuilder.UseSqlite("Data Source=blog.db");

		return new BloggingContext(optionsBuilder.Options);
	}
}

​ “可以通過實現介面來告訴工具如何創建 DbContext,通過創建類實現介面IDesignTimeDbContextFactory<TContext>,如果實現此介面的類在與派生的項目相同的項目中或應用程式的啟動項目中找到,則這些工具將繞過創建 DbContext 的其他方法,並改用設計時工廠。”

​ 問題便可迎刃而解。

3. 總結

​ 以上解決方法僅針對控制台程式使用或測試Entity Framework時出現的問題,因為Asp.net程式按照官網給定的兩種方式去實現的話,不會出現這個問題。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • mybatis是一個很好用的工具,但是編寫mapper是一件很麻煩的事,自mybatis 3.0開始可以使用註解的方式,極大的簡化了xml的編寫量,本地想看看mybatis源碼,自己擴展寫一個工具,在閱讀源碼過程中發現一個通用mapper的工具包,感覺不用重覆造輪子了,簡要記錄一下spring bo ...
  • Java的前世今生 "我的個人博客" "本文視屏" 前言 這一期來講故事 你說為啥這杯咖啡能喝這麼多年還這麼香 讓我們一起來看看這杯咖啡的魔力 現如今一提到 Java開發 就完完全全是spring的事情 一談學習就是 springboot springcloud 好像沒有什麼事情是spring全家桶 ...
  • 定義要求一個子系統的外部與其內部的通信必須通過一個統一的對象進行。 門面模式提供一個高層次的介面, 使得子系統更易於使用。結構Facade:門面(外觀)角色,將收到的請求委派給相應的子系統Subsystem:子系統角色,處理請求,並不知道門面的存在,只是一個正常的客戶端優點減少系統的相互依賴提高靈活 ...
  • 在講工廠模式的時候,我將講一個早餐店創業故事來慢慢的引入簡單工廠模式,工廠方法模式和抽象工廠模式以及他們各自的區別。 創業初期,由於資金不足,最開始早餐店就賣一種商品包子,包子的種類有3種,肉包,菜包,和糖包,現在我們不用工廠模式來實現下這個代碼: 包子介面: public interface St ...
  • 我們都知道面向對象編程有三大特征:封裝,集成和多態,那我們如何在實際開發中去靈活運用它呢,今天我給大家聊一聊簡單工廠設計模式。簡單工廠設計模式的一個核心思想就是高內聚,低耦合,使具體的業務邏輯實現功能和效果展示分離開來。 先給大家舉一個沒有應用到工廠設計模式的例子: 題目:要求設計一個計算器程式,輸 ...
  • SunnyUI.Net, 基於 C# .Net WinForm 開源控制項庫、工具類庫、擴展類庫、多頁面開發框架 Blog: https://www.cnblogs.com/yhuse Gitee: https://gitee.com/yhuse/SunnyUI GitHub: https://git ...
  • #nginx功能 反向代理,負載均衡,緩存靜態資源,如圖片、CSS、JS #正向代理和反向代理 ##正向代理 代理客戶端,代客戶端發出請求,客戶端知道要訪問的真實地址,如vpn ##反向代理 代理服務端,代服務端接收請求,客戶端不知道要訪問的真實地址 #win10 docker部署nginx對dot ...
  • SunnyUI控制項庫安裝,其實也是常規的Winform控制項庫安裝方法。 ...
一周排行
    -Advertisement-
    Play Games
  • Timer是什麼 Timer 是一種用於創建定期粒度行為的機制。 與標準的 .NET System.Threading.Timer 類相似,Orleans 的 Timer 允許在一段時間後執行特定的操作,或者在特定的時間間隔內重覆執行操作。 它在分散式系統中具有重要作用,特別是在處理需要周期性執行的 ...
  • 前言 相信很多做WPF開發的小伙伴都遇到過表格類的需求,雖然現有的Grid控制項也能實現,但是使用起來的體驗感並不好,比如要實現一個Excel中的表格效果,估計你能想到的第一個方法就是套Border控制項,用這種方法你需要控制每個Border的邊框,並且在一堆Bordr中找到Grid.Row,Grid. ...
  • .NET C#程式啟動閃退,目錄導致的問題 這是第2次踩這個坑了,很小的編程細節,容易忽略,所以寫個博客,分享給大家。 1.第一次坑:是windows 系統把程式運行成服務,找不到配置文件,原因是以服務運行它的工作目錄是在C:\Windows\System32 2.本次坑:WPF桌面程式通過註冊表設 ...
  • 在分散式系統中,數據的持久化是至關重要的一環。 Orleans 7 引入了強大的持久化功能,使得在分散式環境下管理數據變得更加輕鬆和可靠。 本文將介紹什麼是 Orleans 7 的持久化,如何設置它以及相應的代碼示例。 什麼是 Orleans 7 的持久化? Orleans 7 的持久化是指將 Or ...
  • 前言 .NET Feature Management 是一個用於管理應用程式功能的庫,它可以幫助開發人員在應用程式中輕鬆地添加、移除和管理功能。使用 Feature Management,開發人員可以根據不同用戶、環境或其他條件來動態地控制應用程式中的功能。這使得開發人員可以更靈活地管理應用程式的功 ...
  • 在 WPF 應用程式中,拖放操作是實現用戶交互的重要組成部分。通過拖放操作,用戶可以輕鬆地將數據從一個位置移動到另一個位置,或者將控制項從一個容器移動到另一個容器。然而,WPF 中預設的拖放操作可能並不是那麼好用。為瞭解決這個問題,我們可以自定義一個 Panel 來實現更簡單的拖拽操作。 自定義 Pa ...
  • 在實際使用中,由於涉及到不同編程語言之間互相調用,導致C++ 中的OpenCV與C#中的OpenCvSharp 圖像數據在不同編程語言之間難以有效傳遞。在本文中我們將結合OpenCvSharp源碼實現原理,探究兩種數據之間的通信方式。 ...
  • 一、前言 這是一篇搭建許可權管理系統的系列文章。 隨著網路的發展,信息安全對應任何企業來說都越發的重要,而本系列文章將和大家一起一步一步搭建一個全新的許可權管理系統。 說明:由於搭建一個全新的項目過於繁瑣,所有作者將挑選核心代碼和核心思路進行分享。 二、技術選擇 三、開始設計 1、自主搭建vue前端和. ...
  • Csharper中的表達式樹 這節課來瞭解一下表示式樹是什麼? 在C#中,表達式樹是一種數據結構,它可以表示一些代碼塊,如Lambda表達式或查詢表達式。表達式樹使你能夠查看和操作數據,就像你可以查看和操作代碼一樣。它們通常用於創建動態查詢和解析表達式。 一、認識表達式樹 為什麼要這樣說?它和委托有 ...
  • 在使用Django等框架來操作MySQL時,實際上底層還是通過Python來操作的,首先需要安裝一個驅動程式,在Python3中,驅動程式有多種選擇,比如有pymysql以及mysqlclient等。使用pip命令安裝mysqlclient失敗應如何解決? 安裝的python版本說明 機器同時安裝了 ...