.Net Entity Framework 实体关系

 Entity Framework 实体关系

.Net Entity Framework 实体关系_第1张图片

  1. 一对一关系(one-to-one)

  a) 单向一对一(文章链接)

  类图:

.Net Entity Framework 实体关系_第2张图片

  数据库表结构:

.Net Entity Framework 实体关系_第3张图片

  Entity Framework中实体关系的定义:

modelBuilder.Entity()
    .HasRequired(b => b.BlogUser)
    .WithMany()
    .HasForeignKey(b => b.UserID);

  b) 双向一对一(文章链接)

  类图:

.Net Entity Framework 实体关系_第4张图片

  数据库表结构:

.Net Entity Framework 实体关系_第5张图片

  Entity Framework中实体关系的定义:

modelBuilder.Entity()
    .HasRequired(b => b.BlogUser)
    .WithMany()
    .HasForeignKey(b => b.UserID);

modelBuilder.Entity()
    .HasRequired(u => u.BlogSite)
    .WithMany()
    .HasForeignKey(u => u.BlogID);

  2. 一对多关系(one-to-many,文章链接)

  类图:

.Net Entity Framework 实体关系_第6张图片

  数据库表结构:

.Net Entity Framework 实体关系_第7张图片

  Entity Framework中实体关系的定义:

modelBuilder.Entity()
    .HasMany(b => b.BlogPosts)
    .WithRequired(p => p.BlogSite);

  3. 多对多关系(many-to-many,文章链接)

  类图:

.Net Entity Framework 实体关系_第8张图片

  数据库表结构:

.Net Entity Framework 实体关系_第9张图片

  Entity Framework中实体关系的定义:

modelBuilder.Entity()
    .HasMany(b => b.Categories)
    .WithMany(c => c.BlogPosts)
    .Map
    (
        m =>
        {
            m.MapLeftKey("BlogPostID");
            m.MapRightKey("CategoryID");
            m.ToTable("BlogPost_Category");
        }
    );

你可能感兴趣的:(技术)