ASP.NETMVC中使用存储库模式实现多对多关系。
创始人
2024-09-19 09:30:49
0
  1. 创建实体类

public class Student { public int Id { get; set; } public string Name { get; set; } public virtual ICollection Courses { get; set; } }

public class Course { public int Id { get; set; } public string Name { get; set; } public virtual ICollection Students { get; set; } }

  1. 创建DbContext

public class ApplicationDbContext : DbContext { public DbSet Students { get; set; } public DbSet Courses { get; set; }

protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
    modelBuilder.Entity()
        .HasMany(s => s.Courses)
        .WithMany(c => c.Students)
        .Map(cs =>
        {
            cs.MapLeftKey("StudentId");
            cs.MapRightKey("CourseId");
            cs.ToTable("StudentCourses");
        });
}

}

  1. 创建存储库

public class CourseRepository : IDisposable { private ApplicationDbContext context = new ApplicationDbContext();

public void AddCoursesToStudent(Student student, List courses)
{
    student.Courses = courses;
    context.SaveChanges();
}

public List GetCoursesForStudent(int studentId)
{
    return context.Students
        .Where(s => s.Id == studentId)
        .SelectMany(s => s.Courses)
        .ToList();
}

public void Dispose()
{
    context.Dispose();
}

}

  1. 控制器和视图

public class HomeController : Controller { private CourseRepository courseRepository = new CourseRepository();

public ActionResult Index()
{
    ViewBag.Courses = courseRepository.GetCoursesForStudent(1);
    return View();
}

[HttpPost]
public ActionResult SaveCourses()
{
    int studentId = int.Parse(Request.Form["studentId"]);
    List courses = Request.Form["courses"]
        .Split(new char[] { ',' }, StringSplitOptions.RemoveEmptyEntries)
        .Select(courseId => new Course { Id = int.Parse(courseId) })
        .ToList();

    courseRepository.AddCoursesToStudent(studentId, courses);
    return RedirectToAction("Index");
}

}

@model ProjectName.Models.Student

@{ ViewBag.Title = "Index";

相关内容

热门资讯

第一分钟总结!小闲川南宜宾辅助... 第一分钟总结!小闲川南宜宾辅助,兴动互娱辅助器多少钱(切实真的是有挂)-哔哩哔哩一、兴动互娱辅助器多...
3分钟了解!湖南牵手胡子跑改脚... 3分钟了解!湖南牵手胡子跑改脚本,微友辅助神器下载(原来有挂)-哔哩哔哩1)湖南牵手胡子跑改脚本辅助...
5分钟详细!微乐广西小程序脚本... 5分钟详细!微乐广西小程序脚本,决战卡五星辅助看牌器(竟然真的是有挂)-哔哩哔哩决战卡五星辅助看牌器...
第6分钟专业!新海豚辅助工具,... 第6分钟专业!新海豚辅助工具,决战手游辅助(竟然真的是有挂)-哔哩哔哩1、下载好新海豚辅助工具辅助软...
九分钟必备!微信呢小程序辅助器... 九分钟必备!微信呢小程序辅助器脚本,赣牌圈有挂吗(果然是有挂)-哔哩哔哩运微信呢小程序辅助器脚本辅助...
第6分钟解密!皇豪互众插件,随... 第6分钟解密!皇豪互众插件,随意玩辅助软件(确实有挂)-哔哩哔哩1、完成随意玩辅助软件透视辅助安装,...
六分钟普及!新西部辅助外卦,衢... 六分钟普及!新西部辅助外卦,衢州都莱辅助器下载(原来真的有挂)-哔哩哔哩衢州都莱辅助器下载辅助器中分...
第5分钟解迷!透视辅助功能插件... 第5分钟解迷!透视辅助功能插件下载,新漫游正版辅助软件(其实真的有挂)-哔哩哔哩1、透视辅助功能插件...
六分钟关于!四川途游辅助软件,... 六分钟关于!四川途游辅助软件,新518互游插件下载(好像真的是有挂)-哔哩哔哩1、四川途游辅助软件机...
第6分钟详情!指尖四川辅助脚本... 第6分钟详情!指尖四川辅助脚本苹果版,宁夏划水辅助(一直是真的挂)-哔哩哔哩1、上手简单,内置详细流...