可指定其他配置以补充和/或替代约定的内容。
提供程序还可支持特定于具体数据存储的配置。
1、使用 fluent API 配置模型
Fluent API 配置具有最高优先级,并将替代约定和数据注释。
using Microsoft.EntityFrameworkCore; namespace EFModeling.FluentAPI.Required { class MyContext : DbContext { public DbSet<Blog> Blogs { get; set; } #region Required protected override void OnModelCreating(ModelBuilder modelBuilder) { modelBuilder.Entity<Blog>() .Property(b => b.Url) .IsRequired(); } #endregion } public class Blog { public int BlogId { get; set; } public string Url { get; set; } } }
分组配置
为了减小 OnModelCreating 方法的大小,可以将实体类型的所有配置提取到实现 IEntityTypeConfiguration<TEntity> 的单独类中。
public class BlogEntityTypeConfiguration : IEntityTypeConfiguration<Blog> { public void Configure(EntityTypeBuilder<Blog> builder) { builder .Property(b => b.Url) .IsRequired(); } }
然后,只需从 OnModelCreating 调用 Configure 方法:
new BlogEntityTypeConfiguration().Configure(modelBuilder.Entity<Blog>());
可以在给定程序集中应用实现 IEntityTypeConfiguration 的类型中指定的所有配置:
modelBuilder.ApplyConfigurationsFromAssembly(typeof(BlogEntityTypeConfiguration).Assembly);
2、使用数据注释来配置模型
数据注释会替代约定,但会被 Fluent API 配置替代:
using Microsoft.EntityFrameworkCore; using System.ComponentModel.DataAnnotations; namespace EFModeling.DataAnnotations.Required { class MyContext : DbContext { public DbSet<Blog> Blogs { get; set; } } #region Required public class Blog { public int BlogId { get; set; } [Required] public string Url { get; set; } } #endregion }