zoukankan      html  css  js  c++  java
  • .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文件夹,这个是项目的迁移记录。

    我曾七次鄙视自己的灵魂:
    第一次,当它本可进取时,却故作谦卑;
    第二次,当它空虚时,用爱欲来填充;
    第三次,在困难和容易之间,它选择了容易;
    第四次,它犯了错,却借由别人也会犯错来宽慰自己;
    第五次,它自由软弱,却把它认为是生命的坚韧;
    第六次,当它鄙夷一张丑恶的嘴脸时,却不知那正是自己面具中的一副;
    第七次,它侧身于生活的污泥中虽不甘心,却又畏首畏尾。
  • 相关阅读:
    代码1
    js中级第13天
    dom 浏览器模型
    js中级第12天
    js中级第11天
    js中级第十天
    js中级第九天
    js中级第8天
    js中级第六天
    js中级第七天
  • 原文地址:https://www.cnblogs.com/chenxi001/p/14377672.html
Copyright © 2011-2022 走看看