代码改变世界

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

2020-06-07 13:59  若藜520  阅读(270)  评论(0编辑  收藏  举报

转自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使用