10.1.翻译系列:EF 6中的实体映射【EF 6 Code-First系列】
原文链接:https://www.entityframeworktutorial.net/code-first/configure-entity-mappings-using-fluent-api.aspx Fluent API可以配置实体,为其映射为数据表,默认的模式等。 ######配置默认的模式 首先,让我们来配置数据库中数据表的默认的模式名吧。当然你可以在配置单独的表的时候,改变这个默认的模式。下面的代码设置默认的模式名为Admin,所有的数据库对象都将会是你配置的这个模式名。 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类型的属性所生成的表,例如: 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
######映射实体为多个表 下面的例子,演示了将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实体将会拆分为两个数据表: Map方法需要一个委托类型的参数,你可以在Man方法中传递Action委托或者lambda表达式,例如: 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.DateOfBirth });
m.ToTable("StudentInfoDetail");
};
modelBuilder.Entity<Student>().Map(studentMapping);
modelBuilder.Entity<Standard>().ToTable("StandardInfo");
}
}
}
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- 将“onclick”属性添加到asp.net下拉列表项
- asp.net-mvc – 控制器没有从不同的程序集加载?
- ASP.NET站点.将整个域从http重定向到https
- asp.net读取excel文件的三种方法示例
- asp.net-mvc – MVC帮助 – 使用@URL的图像src?
- asp.net-mvc – asp.net MVC中RavenDB中的多租户索引
- 扩展Asp.Net需要帮助
- asp.net-mvc-3 – ASP.MVC 3 Razor在Html.PartialView扩展中
- asp.net-mvc – 在ASP.NET MVC 3中用逻辑构建子视图的好方法
- 为什么IIS不会执行我的自定义404页面?它试图改为提供原始源
- asp.net – 计算SQL中值的总和,以显示每月名称
- 非锁定进程中的ASP.NET会话状态存储
- asp.net-mvc-3 – asp.net mvc 3应用程序中的默认
- asp.net-mvc-3 – 在MVC 3上启用黄屏死机
- asp.net – coldfusion和.net上的单点登录
- asp.net-mvc-4 – 将项目升级到MVC 5
- 一步步开发自己的博客 .NET版(4、文章发布功能
- asp.net-core – 不使用HTTPS的ASP.NET 5 OAuth重
- asp.net – 为什么viewstate序列化为表单中的隐藏
- asp.net-core-mvc – 如何在Asp.Net Core中自定义