Loading

.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文件夹,这个是项目的迁移记录。

posted @ 2021-02-05 14:48  是你晨曦哥呀  阅读(1391)  评论(0编辑  收藏  举报