EF Core Fluent API怎么用 EF Core Fluent API入门教程

admin 百科 13
EF Core Fluent API 是在 OnModelCreating 方法中通过 ModelBuilder 配置模型的推荐方式,比数据注解更灵活、解耦更强,适合复杂场景;配置必须在此方法中编写,建议拆分到实现 IEntityTypeConfiguration 的独立类中;支持表名列名修改、主键设置、索引与关系配置等。

EF Core Fluent API怎么用 EF Core Fluent API入门教程-第1张图片-佛山资讯网

EF Core Fluent API 是在 OnModelCreating 方法中通过 ModelBuilder 对象配置模型的推荐方式,比数据注解更灵活、解耦更强,也更适合复杂场景。它不依赖属性标记,所有配置集中管理,便于维护和跨数据库适配。

在哪写 Fluent API 配置

重写 DbContext 类中的 OnModelCreating 方法,在里面调用 modelBuilder 的链式方法:

  • 配置入口固定:必须在 protected override void OnModelCreating(ModelBuilder modelBuilder) 中编写
  • 不能在构造函数或 OnConfiguring 中调用,否则会报错
  • 建议把不同实体的配置拆到单独的配置类(实现 IEntityTypeConfiguration<t></t>),再在 OnModelCreating 中批量注册,保持主方法简洁

最常用的基础配置示例

以下是在 OnModelCreating 中直接写的典型操作:

  • 改表名modelBuilder.Entity<user>().ToTable("Users")</user>
  • 改列名 + 类型 + 长度modelBuilder.Entity<user>().Property(u => u.Email).HasColumnName("email_address").HasColumnType("varchar(255)").IsRequired()</user>
  • 设主键 + 自增modelBuilder.Entity<order>().HasKey(o => o.Id); modelBuilder.Entity<order>().Property(o => o.Id).ValueGeneratedOnAdd()</order></order>
  • 设复合主键modelBuilder.Entity<orderitem>().HasKey(oi => new { oi.OrderId, oi.ProductId })</orderitem>

索引与关系怎么配

索引和导航关系是性能和数据完整性关键,Fluent API 提供清晰语法:

标签: mysql ai 为什么 red

发布评论 0条评论)

还木有评论哦,快来抢沙发吧~