EntityFramework 有几种方式可实现数据库表与实体的关系配置(relationship)
- convention -
- annotation -
- fluent api -
使用数据注解
实体类通常是在Models
目录下,直接在实体类上添加属性注解,比如[Required]/[Key]
等.
using System.ComponentModel.DataAnnotations;
public class User()
{
[Key]
public string UserId { get; set; }
[Required]
public string UserName { get; set; }
}
重写配置方法
在自己实现的XxxDbContext
数据库上下文类中重写配置方法,用Fluent API
的方式添加所有实体的配置.
using Microsoft.EntityFrameworkCore;
public partial class XxxDbContext : DbContext
{
public XxxDbContext()
{
}
public HaoyikuDbContext(DbContextOptions<HaoyikuDbContext> options)
: base(options)
{
}
public DbSet<User> Users { get; set; }
// 重写以下方法
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
// 添加实体的配置
modelBuilder.Entity<BizOrderPush>().HasKey();
}
}
实现实体类配置接口
新建
ModelConfigurations
目录,在该目录下新增每一个实体对应的配置类.using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore.Metadata.Builders;
///
/// 用户实体-模型配置 /// public class UserConfiguration : IEntityTypeConfiguration{ public void Configure(EntityTypeBuilder builder) { builder.HasKey(o => o.UserId); builder.Property(o => o.UserName).IsRequired(); } }
单独配置每一个实体类后,通过以下方法设置
using Microsoft.EntityFrameworkCore;
public partial class XxxDbContext : DbContext
{
public XxxDbContext()
{
}
public HaoyikuDbContext(DbContextOptions<HaoyikuDbContext> options)
: base(options)
{
}
public DbSet<User> Users { get; set; }
// 重写以下方法
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
// 添加实体的配置
modelBuilder.ApplyConfiguration(new UserConfiguration());
base.OnModelCreating(modelBuilder);
}
}
以上几种方式可以共存,至于到底用哪种,推荐用哪种,各位看着办吧.