ASP.NETMVC中一对多关系ViewModel的CRUD操作
创始人
2024-11-12 05:00:33
0

首先,我们需要定义一对多关系的ViewModel。假设我们有一个学校,一个学校可以有多个班级,每个班级又可以有多个学生。我们可以定义以下ViewModel:

public class SchoolViewModel{
    public int SchoolId { get; set; }
    public string Name { get; set; }
    public List Classes { get; set; }
}

public class ClassViewModel{
    public int ClassId { get; set; }
    public string Name { get; set; }
    public List Students { get; set; }
}

public class StudentViewModel{
    public int StudentId { get; set; }
    public string Name { get; set; }
}

接下来,我们可以创建包含一些基本操作的控制器,如下所示:

public class SchoolController : Controller{
    private readonly ApplicationDbContext _context;

    public SchoolController(ApplicationDbContext context){
        _context = context;
    }

    public IActionResult Index(){
        List schools = new List();
        foreach (var school in _context.Schools){
            var classes = _context.Classes.Where(c => c.SchoolId == school.SchoolId)
                                          .Select(c => new ClassViewModel{
                                              ClassId = c.ClassId,
                                              Name = c.Name,
                                              Students = _context.Students.Where(s => s.ClassId == c.ClassId)
                                                                         .Select(s => new StudentViewModel{
                                                                             StudentId = s.StudentId,
                                                                             Name = s.Name
                                                                         })
                                                                         .ToList()
                                          })
                                          .ToList();
            schools.Add(new SchoolViewModel{
                SchoolId = school.SchoolId,
                Name = school.Name,
                Classes = classes
            });
        }
        return View(schools);
    }

    public IActionResult Create(){
        return View();
    }

    [HttpPost]
    public async Task Create(SchoolViewModel schoolViewModel){
        if (ModelState.IsValid){
            School school = new School{
                Name = schoolViewModel.Name
            };
            _context.Schools.Add(school);
            await _context.SaveChangesAsync();
            return RedirectToAction(nameof(Index));
        }
        return View(schoolViewModel);
    }

    public async Task Edit(int id){
        var school = await _context.Schools.FindAsync(id);
        if (school == null){
            return NotFound();
        }
        SchoolViewModel schoolViewModel = new SchoolViewModel{
            SchoolId = school.SchoolId,
            Name = school.Name,
            Classes = _context.Classes.Where(c => c.SchoolId == school.SchoolId)
                                       .Select(c => new ClassViewModel{
                                           ClassId = c.ClassId,
                                           Name = c

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...