EFCore 从入门到精通-3(模型创建)

1.准备条件

	开发软件:VisualStudio2022,EFCore6.0
	.net Core版本:.Net6.0
	数据库:mysql8.0
	数据库管理软件:Navicat

2.EFCore的使用流程

通过前面的描述我们来总结下,使用EFCore(CodeFirst)的基本流程:

  • 创建 DbContext 实例 根据上下文跟踪实体实例。
  • 创建 实体模型,在DbContext 实例类中添加DbSet<实体>属性。
  • 根据业务需求进行增删改查, 调用 SaveChanges 或 SaveChangesAsync,将更改应用到数据库

3.DBContext中的配置

前面已经说过,除非你的数据库已经存在,否则不推荐使用反向工程来通过数据库创建模型,一般推荐使用CodeFirst模式,即代码先行的原则。
在DBContext类中,最重要,也是我们最常用的两个方法就是:
"OnConfiguring"和 “OnModelCreating” 如下:

     protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
   
            if (!optionsBuilder.IsConfigured)
            {
   

                optionsBuilder.UseMySql("server=172.10.14.144;database=EFCoreLearn;user=root;password=123456", Microsoft.EntityFrameworkCore.ServerVersion.Parse("8.0.28-mysql"));
            }
        }

        protected override void OnModelCreating(ModelBuilder modelBuilder)
        {
   
            modelBuilder.UseCollation("utf8_general_ci")
                .HasCharSet("utf8");

            modelBuilder.Entity<Student>(entity =>
            {
   
                entity.Property(e => e.Class).HasMaxLength(50);

                entity.Property(e => e.Name).HasMaxLength(50);
            });

            OnModelCreatingPartial(modelBuilder);
        }
3.1 OnConfiguring

在创建自己的DbContext子类时,重写此方法可以自己进行数据库的配置,以及其他选项的配置。其中主要有以下常用的配置:

  • 配置连接字符串
  • 配置输出的Logger
  • 配置过滤和拦截操作
  • 禁用和启用并发
 protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
   
            if (!optionsBuilder.IsConfigured)
            {
   

                optionsBuilder.UseMySql("server=172.10.14.144;database=EFCoreLearn;user=root;password=123456", Microsoft.EntityFrameworkCore.ServerVersion.Parse("8.0.28-mysql"));
                optionsBuilder.LogTo(Console.WriteLine);//日志输出到控制台
                optionsBuilder.AddInterceptors(new SoftDeleteInterception()); //添加拦截器软删除

                optionsBuilder.EnableThreadSafetyChecks(false);//关闭并安全检测

            }
        }
       }

过滤拦截配置,是在数据库连接的时候,执行命令的时候,或者保存的时候执行的一些特所的操作,一般要实现继承以下几个类实现自己的定义操作:

抽型类

  • DbConnectionInterceptor —数据库连接的时候进行一些操作
  • DbTransactionInterceptor —数据库执行时候的时候进行一些操作
  • DbCommandInterceptor —数据库执行命令的时候进行一些操作
  • SaveChangesInterceptor —数据库保存的时候进行一些操作
    以下为相同含义的接口
  • IDbCommandInterceptor
  • IDbConnectionInterceptor
  • IDbTransactionInterceptor
  • ISaveChangesInterceptor
3.2 OnModelCreating

重写此方法,可以对实体类也可以说是数据表进行模型配置。
模型配置主要分为两种方法:

  • FluentAPI
  • 数据注解

在OnModelCreating里使用的是fluentAPI

  protected override void OnModelCreating(ModelBuilder modelBuilder)
        {
   
            modelBuilder.UseCollation("utf8_general_ci")
                .HasCharSet("utf8");

            modelBuilder.Entity<Student>(entity =>
            {
   
                entity.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值