EntityFrameWork 多对多关系处理

场景2: 一个文章类别(Category)下含有多篇文章(Article),而文章也可能对应多个类别

Article和Category的代码更改如下:

/// <summary>
/// 文章信息
/// </summary>
public class Article:ModelBase
{
    /// <summary>
    /// 类别名字
    /// </summary>
    public string Name { get; set; }

    public ICollection<Category> Categorys { get; set; }
}
public class Category : ModelBase
{
    /// <summary>
    /// 类别名字
    /// </summary>
    public string Name { get; set; }

    public ICollection<Article> Articles { get; set; }
}

然后在Entity Framework的OnModelCreating中通过Fluent API定义“多对多”关系
如下配置会在数据库生成一张叫ArticleCategory的表属性分别为ArticleID和CategoryID

public class CmsDbContext : DbContextBase
{
    public CmsDbContext():base(CachedConfigContext.Current.DaoConfig.Cms,new LogDbContext()) { 

    }
    protected override void OnModelCreating(DbModelBuilder modelBuilder)
    {
        Database.SetInitializer<CmsDbContext>(null);
        modelBuilder.Entity<Article>().HasMany(a => a.Categorys)
            .WithMany(c => c.Articles)
            .Map(u =>
            {
                u.MapLeftKey("ArticleID");
                u.MapRightKey("CategoryID");
                u.ToTable("ArticleCategory");

            });
        base.OnModelCreating(modelBuilder);
    }

    public DbSet<Category> Categorys { get; set; }
    public DbSet<Article> Articles { get; set; }

}

分别编写两个场景来测试以下结果:

public interface ICmsService
{
    //通过文章id获取文章同时加载该文章所有类别信息
    Article GetArticle(int articleId);
    //通过类别id获取类别同时加载该类别下所有文章
    Category GetCategory(int categoryId);
}

接口实现类:

public class CmsService : ICmsService
{
    public Article GetArticle(int articleId)
    {
        using (var dbContext = new CmsDbContext())
        {
            return dbContext.Articles.Include("Categorys").FirstOrDefault(a => a.ID == articleId);
        }
    }

    public Category GetCategory(int categoryId)
    {
        using (var dbContext = new CmsDbContext())
        {
            return dbContext.Categorys.Include("Articles").FirstOrDefault(c => c.ID == categoryId);
        }
    }
}

这里使用ASP.NET MVC来显示结果,在View中传入的model可以在视图的Model对象直接获取数据(需要在视图页指定类型)

public class ArticleController: AdminControllerBase
{
    public ActionResult Index()
    {
        var models = this.CmsService.GetArticle(1);
        return View(models);
    }
}

Razor视图页编写如下:

@model Qxun.Cms.Contract.Article

<h2>显示文章的所有类型</h2>

@if (Model!=null)
{
    @Model.Name<br/>
    foreach (var item in Model.Categorys)
    {
        <span>@item.Name</span><span>|@item.CreateTime</span> <br/>
    }
}

通过下面的结果发现,已经把文章相关的类别加载进来了。通过类别加载文章原理是一样的,就不再写一遍了。

时间: 2024-10-24 01:09:42

EntityFrameWork 多对多关系处理的相关文章

EntityFramework之多对多关系(四)

上篇介绍了一对多关系,下面介绍下多对多关系代码编写. 1.新建model实体,User是用户类,Role是角色类,由于是多对多关系,必须得有一个中间类,所以产生了UserRole类 1 public class User 2 { 3 public int Id { get; set; } 4 public string Name { get; set; } 5 6 public virtual ICollection<UserRole> UserRoles { set; get; } 7 }

EntityFramework Core2.0 多对多关系配置

? 在EF6.0 中,多对多关系配置时,系统会自动生成第三张表,来将两张有互相约束关系的表联系起来,但是在EF Core2.0中,我们需要手动建立第三张表,比如说有两个模型Passage.cs和Category.cs,若想建立两者之间的多对多关系,我们就需要借助第三张表PassageCategory来实现: public class Passage { //文章编号 [Key] public long PassageId { get; set; } //标题 public string Titl

[C#/.NET]Entity Framework(EF) Code First 多对多关系的实体增,删,改,查操作全程详细示例

本文我们来学习一下在Entity Framework中使用Context删除多对多关系的实体是如何来实现的.我们将以一个具体的控制台小实例来了解和学习整个实现Entity Framework 多对多关系的实体删除的操作过程. 你将学习到 怎样创建一个引用Entity Framework的项目: 怎样配置Entity Framework的数据库连接: 怎样去掉Entity Framework Code First 生成的表名的复数: 怎样通过EntityTypeConfiguartion配置实体的

Laravel5.1 模型 --多对多关系

多对多关系也是很常用的一种关系,比如一篇文章可以有多个标签,一个标签下也可以有多篇文章,这就是一个典型的多对多的关系. 1 实现多对多关系 多对多关系我们需要三张表,一张是文章另一张是标签,第三章表是它们的中间表 因为多对多关系需要抽离成两个一对多关系嘛. 1.1 文章结构 public function up() { Schema::create('articles', function (Blueprint $table) { $table->increments('id'); $table

ASP.NET MVC with Entity Framework and CSS一书翻译系列文章之第六章:管理产品图片:多对多关系(上)

这章介绍了怎样创建一个新的实体来管理图片,怎样使用HTML窗体来上传图片文件和使用多对多关系来使它们与产品相关,并且怎样来保存图片到文件系统中.这章也介绍了更多复杂的错误处理增加客户端错误到模型中为了把它们显示回给用户.在这章中播种数据库使用的产品图片可能在在第六章的从Apress网页站点下载代码中. 注意:如果你想遵从这章的代码,你必须完成第五章的代码或者从www.apress.com下载第五章的源代码作为一个起点. 创建实体保存图片文件名 这个项目,我们正要使用文件系统在Web项目中存储图片

MySql多对多关系中外键的应用

业务需求:用户表r_user保存用户名等信息.现需要给每个用户设置工作基地,一个用户可以有多个工作基地,多个用户也可以有一个工作基地,即多对多关系.(外键,若有两个表A,B,C是A的主键,而B中也有C字段,则C就是表B的外键,外键约束主要用来维护两个表之间数据的一致性) 设计方案: 方案一:建立一张用户基地表,与r_user与用户基地表,保持一对多的关系,如图所示,r_user的主键id做为r_user_base的外键user_id.通过r_user中的id,在r_user_base表中load

Castle.ActiveRecord 多对多关系 引发的错误处理

在Castle.ActiveRecord 实体类中,如果两个对象有 “多对多” 关系,一般的做法是将其分解为 两个“一对多”关系,但有时引发了 “您要删除 或 引用 的对象#2在数据库中不存在”的异常 百思不得其解,同样的用法在“媒体引用”中一直都是正常的,为什么在“专题引用” 和“ Web栏目引用” 中就出现异常呢? 通过遍历代码发现了细微的差别: 在“媒体”的业务对象加载时,为了判断一个对象是否可以删除,常查询其被引用的 次数是多少,使用的方法是:DALMediaReference.Find

在thinkphp中,写的博文标签多对多关系的标签频率统计算法

常常看到别人的博客里面,或者网站里面有这样随机颜色,但字体大小与标签出现频率有关的标签云,于是自己就想写一个.至于颜色的随机显示,那就很简单了,这里就不列代码. 因为正在学thinkphp,所以数据查找的都是用的tp数据查找语句. 1 Public function render( $data ){ 2 //在博文——标签多对多关系的中间表中查找出所有的标签 3 $tags = M('blog_tags')->select(); 4 $a = array(); 5 //去掉重复的标签,将所有不重

jpa双向多对多关系

多对多关系相比其他其中关联关系,显得稍微复杂了一点点,这个复杂度主要体现在对这种关联关系的理解上.和其他关联关系不同的是这种关联多出来了一张中间表,操作上多了些许复杂,来随便看下吧 1  实体的定义 Student表: package org.lxh.info; import java.util.*; import javax.persistence.CascadeType; import javax.persistence.Column; import javax.persistence.En