.Net Core 使用EF Core codefirst模式


.Net Core 使用EF Core codefirst模式

什么是codefirst模式

EF Core有兩種數據庫設計模式,DBfirst 數據庫優先、Codefirst 代碼優先。
1、我們一般設計是先添加數據庫表信息,然后將數據庫的信息更新到項目實體中。這種做法就是我們的DBfirst模式。
2、使用codefirst模式,我們就可以先創建表實體,添加字段限制,完事之后執行3中的兩條命令就好了,真的很香呀。
3、代碼遷移:Add-Migration "更新內容"、數據庫更新:update-database。

codefirst模式的使用

首先你要創建一個項目,我使用的.net 5 創建了一個類庫,然后我們先引用基本EF Core的基本類庫、再然后創建一個數據庫上下文,添加實體,執行語句就下班啦。

首先我是連接mysql數據庫,其他數據庫一樣的操作,只是引用的包不一樣。
1、Microsoft.EntityFrameworkCore
2、Microsoft.EntityFrameworkCore.Design
3、Microsoft.EntityFrameworkCore.Tools
4、Pomelo.EntityFrameworkCore.MySql

       /// <summary>
       /// 數據庫連接對象
       /// </summary>
       public class ShopMorningContext : DbContext
       {
              public ShopMorningContext()
              {

              }

              public ShopMorningContext(DbContextOptions option) : base(option)
              {

              }

              public DbSet<Sys_User> Sys_Users { set; get; }

              public DbSet<User_Address> User_Addresss { set; get; }

              /// <summary>
              /// 重寫父類的方法 用於連接數據庫
              /// </summary>
              /// <param name="optionsBuilder"></param>
              protected override void OnConfiguring(DbContextOptionsBuilder 
optionsBuilder)
              {
                     if (!optionsBuilder.IsConfigured)
                     {
                           optionsBuilder.UseMySql(
                                         "Server=xxx;Port=xxx;Database=xxx;Uid=xxx;Pwd=xxx;",
                                         new MySqlServerVersion(new Version(8, 0, 
21)),
                                         mySqlOptions => mySqlOptions
                                                .CharSetBehavior(CharSetBehavior.NeverAppend))
                                  .EnableSensitiveDataLogging()
                                  .EnableDetailedErrors();
                     }
              }
       }

當我們添加好了數據庫上下文對象之后,也添加數據庫實體就可以執行命令啦(下圖是執行命令的地方,怕你第一次聽說這個東西。)

代碼遷移:Add-Migration "更新內容"、數據庫更新:update-database。

執行完之后項目會多一個Migrations文件夾,這個是項目的遷移記錄。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM