目录
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.