原文连接:https://www.entityframeworktutorial.net/code-first/configure-entity-mappings-using-fluent-api.aspxhtml
EF 6 Code-First系列文章目录:typescript
Fluent API能够配置实体,为其映射为数据表,默认的模式等。数据库
首先,让咱们来配置数据库中数据表的默认的模式名吧。固然你能够在配置单独的表的时候,改变这个默认的模式。下面的代码设置默认的模式名为Admin,全部的数据库对象都将会是你配置的这个模式名。api
public class SchoolContext: DbContext
{
public SchoolDBContext(): base() {
}
public DbSet<Student> Students { get; set; }
public DbSet<Standard> Standards { get; set; }
protected override void OnModelCreating(DbModelBuilder modelBuilder) {
//Configure default schema
modelBuilder.HasDefaultSchema("Admin");
}
}
Code-First将会以上下文类中的DbSet类型的属性,建立数据表。在这个例子中是Students和Standards表。你能够单独指定表名,以重写DBset类型的属性所生成的表,例如:app
namespace CodeFirst_FluentAPI_Tutorials
{
public class SchoolContext: DbContext
{
public SchoolDBContext(): base() {
}
public DbSet<Student> Students { get; set; }
public DbSet<Standard> Standards { get; set; }
protected override void OnModelCreating(DbModelBuilder modelBuilder) {
//Configure default schema
modelBuilder.HasDefaultSchema("Admin");
//Map entity to table
modelBuilder.Entity<Student>().ToTable("StudentInfo");
modelBuilder.Entity<Standard>().ToTable("StandardInfo","dbo");
}
}
}
正如上面代码所见,咱们配置以Entity()方法开始,大多数的时候,使用Fluent API,你必需要以这个方法开始。咱们使用ToTable()方法,将Student实体映射为StudentInfo表,将Standard实体映射为StandardInfo表,而且单独配置了StandardInfo表的模式名为dbo.
ide
下面的例子,演示了将Student实体,映射为多个表。测试
namespace CodeFirst_FluentAPI_Tutorials
{
public class SchoolContext: DbContext
{
public SchoolDBContext(): base()
{
}
public DbSet<Student> Students { get; set; }
public DbSet<Standard> Standards { get; set; }
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Entity<Student>().Map(m =>
{
m.Properties(p => new { p.StudentId, p.StudentName});
m.ToTable("StudentInfo");
}).Map(m => {
m.Properties(p => new { p.StudentId, p.Height, p.Weight, p.Photo, p.DateOfBirth});
m.ToTable("StudentInfoDetail");
});
modelBuilder.Entity<Standard>().ToTable("StandardInfo");
}
}
}
正如上面代码所示,咱们将Student实体的一些属性映射为StudentInfo表,使用Map方法将Student实体的另一些属性映射为StudentInfoDetail表,因此Student实体将会拆分为两个数据表:
ui
Map方法须要一个委托类型的参数,你能够在Man方法中传递Action委托或者lambda表达式,例如:spa
using System.Data.Entity.ModelConfiguration.Configuration;
namespace CodeFirst_FluentAPI_Tutorials
{
public class SchoolContext: DbContext
{
public SchoolDBContext(): base() {
}
public DbSet<Student> Students { get; set; }
public DbSet<Standard> Standards { get; set; }
protected override void OnModelCreating(DbModelBuilder modelBuilder) {
modelBuilder.Entity<Student>().Map(delegate(EntityMappingConfiguration<Student> studentConfig)
{
studentConfig.Properties(p => new { p.StudentId, p.StudentName });
studentConfig.ToTable("StudentInfo");
});
Action<EntityMappingConfiguration<Student>> studentMapping = m =>
{
m.Properties(p => new { p.StudentId, p.Height, p.Weight, p.Photo, p.DateOfBirth });
m.ToTable("StudentInfoDetail");
};
modelBuilder.Entity<Student>().Map(studentMapping);
modelBuilder.Entity<Standard>().ToTable("StandardInfo");
}
}
}