转 Code First 数据注释--InverseProperty 和 ForeignKey

Posted lidaying5

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了转 Code First 数据注释--InverseProperty 和 ForeignKey相关的知识,希望对你有一定的参考价值。

转自https://www.cnblogs.com/goodlucklzq/p/4538500.html

ForeignKey

按照约定在Post类中看到BlogId属性,会认为是Blog类的外键,但是在Blog类中并没有BlogId属性,解决方法是,在 Post 中创建一个导航属性,并使用 Foreign DataAnnotation 来帮助 Code First 了解如何在两个类之间创建关系(那就是使用 Post.BlogId 属性)以及如何在数据库中指定约束。

public class Post 
{ 
        public int Id { get; set; } 
        public string Title { get; set; } 
        public DateTime DateCreated { get; set; } 
        public string Content { get; set; } 
        public int BlogId { get; set; } 
        [ForeignKey("BlogId")] 
        public Blog Blog { get; set; } 
        public ICollection<Comment> Comments { get; set; } 
}

设置了ForeignKey的情况:

技术图片

没设置的情况:

技术图片

InverseProperty

当类之间存在多个关系时,将使用InverseProperty

在 Post 类中,可能需要跟踪是谁撰写了博客文章以及谁编辑了它。下面是 Post 类的两个新的导航属性。

public Person CreatedBy { get; set; } 
public Person UpdatedBy { get; set; }

还需要在这些属性引用的 Person 类中添加内容。Person 类具有返回到 Post 的导航属性,一个属性指向该用户撰写的所有文章,一个属性指向该用户更新的所有文章。

public class Person 
{ 
        public int Id { get; set; } 
        public string Name { get; set; } 
        public List<Post> PostsWritten { get; set; } 
        public List<Post> PostsUpdated { get; set; } 
}

设置了InverseProperty

技术图片

未设置InverseProperty

技术图片

 
 
个人理解:
每个导航属性需要一个外键属性来确认两个表之间的关系,正常情况下,如果字段按照 "<导航属性名称><主体主键属性名称>"、"<主体类名称><primary key 属性名称>" 或 "<主体主键属性名称>"约定命名,那么这个字段将会被认为是外键。但是如果没有按照这个约定命名,又需要指定该字段为外键就需要用到ForeignKey,
 比如文中在导航属性上使用批注[ForeignKey("BlogId")] 的意思是将字段BlogId作为外键,并和该导航属性对应。
 
如果一个从属表中只有一个导航属性,导航属性会使用表中仅有的一个外键对应,但是如果有两个导航属性,Code-First并不知道导航属性对应的外键是哪个,所以需要结合ForeignKey和InverseProperty使用
 
 

以上是关于转 Code First 数据注释--InverseProperty 和 ForeignKey的主要内容,如果未能解决你的问题,请参考以下文章

转:Entity Framework 5.0 Code First全面学习

(转)基于现有数据库的Code First模式迁移更新数据库

《Entity Framework 6 Recipes》中文翻译系列 -----第二章 实体数据建模基础之使用Code First建模自引用关系 (转)

1.使用Entity Framwork框架常用的技术手段Code First 和Reverse Engineer Code First

第二节:创建模型,使用Code First,配置映射关系

EF-CodeFirst-基础