- 首先在数据库中创建一个关系表(中间表)以保存多对多关系。
- 在模型类中声明关系,例如:
public class Student
{
public int StudentId { get; set; }
public string Name { get; set; }
public ICollection Courses { get; set; }
}
public class Course
{
public int CourseId { get; set; }
public string Title { get; set; }
public ICollection Students { get; set; }
}
- 在上述模型中使用 [ForeignKey] 和 [InverseProperty] 属性来指定相应的外键和反向导航属性。确保通过中间表建立正确的多对多关系。
- 在视图中使用 @Html.HiddenFor 和 @Html.CheckBoxFor 显示对应关系的数据和状态。
- 在控制器中,执行上述关系的更新操作,例如:
[HttpPost]
public IActionResult Edit(int studentId, List selectedCourseIds)
{
Student student = _context.Students
.Include(s => s.Courses)
.Single(s => s.StudentId == studentId);
student.Courses = new List();
if (selectedCourseIds != null)
{
foreach (int courseId in selectedCourseIds)
{
Course course = _context.Courses.Find(courseId);
student.Courses.Add(course);
}
}
_context.SaveChanges();
return RedirectToAction("Index");
}
- 在更新操作完成后,重定向到合适的视图页面。