Entity Framework 实体关系
1. 一对一关系(one-to-one)
a) 单向一对一(文章链接)
类图:
数据库表结构:
Entity Framework中实体关系的定义:
modelBuilder.Entity<BlogSite>() .HasRequired(b => b.BlogUser) .WithMany() .HasForeignKey(b => b.UserID);
b) 双向一对一(文章链接)
类图:
数据库表结构:
Entity Framework中实体关系的定义:
modelBuilder.Entity<BlogSite>() .HasRequired(b => b.BlogUser) .WithMany() .HasForeignKey(b => b.UserID); modelBuilder.Entity<BlogUser>() .HasRequired(u => u.BlogSite) .WithMany() .HasForeignKey(u => u.BlogID);
2. 一对多关系(one-to-many,文章链接)
类图:
数据库表结构:
Entity Framework中实体关系的定义:
modelBuilder.Entity<BlogSite>() .HasMany(b => b.BlogPosts) .WithRequired(p => p.BlogSite);
3. 多对多关系(many-to-many,文章链接)
类图:
数据库表结构:
Entity Framework中实体关系的定义:
modelBuilder.Entity<BlogPost>() .HasMany(b => b.Categories) .WithMany(c => c.BlogPosts) .Map ( m => { m.MapLeftKey("BlogPostID"); m.MapRightKey("CategoryID"); m.ToTable("BlogPost_Category"); } );