Ядро AspNet Отображение нескольких записей в виде одной строки с несколькими столбцами в таблице - PullRequest
0 голосов
/ 12 июня 2019

У меня проблемы с просмотром таблицы.

Я хочу, чтобы мой стол выглядел следующим образом

  Name  | Test1 | Test2 | Test3  
================================
Anna    | 70    |   51  |  90
================================
Jack    | 56    |   77  |  82
================================

Теперь у меня есть

  Name  | Grade |   Test   | 
================================
Anna    | 70    |   Test1  | 
================================
Anna    | 51    |   Test2  | 
================================
Anna    | 90    |   Test3  | 
================================
Jack    | 56    |   Test1  | 
================================
Jack    | 77    |   Test2  | 
================================
Jack    | 82    |   Test3  | 
================================

Количество тестов является динамическим. Есть какой-либо способ сделать это? Не могу ничего найти. Должен ли я создать другую модель? Или это можно решить, отредактировав View?

Модель

public class StudentsWork
    {
        [Key]
        public int IdStudentsWork { get; set; }
        public int? Grade { get; set; }
        public DateTime? Date { get; set; }
        public int Student_id { get; set; }
        public int Course_id { get; set; }
        public int Test_id { get; set; }
        [ForeignKey("Student_id")]
        public Student StudentId { get; set; }
        [ForeignKey("Course_id")]
        public Course CourseId { get; set; }
        [ForeignKey("Test_id")]
        public Test TestId { get; set; }
    }

Контроллер

    public async Task<IActionResult> Group(int? id,int id_group)
        {
            var group = await _context.StudentsWork
                .Include(p => p.StudentId)
                .ThenInclude(p => p.GroupId)
                .Include(p => p.CourseId)
                .Include(p => p.TestId)
                .Where(c => c.Course_id == id && c.StudentId.Group_id == id_group)
                .ToListAsync();       
            return View(group);
        }

Любая помощь будет принята с благодарностью.

1 Ответ

0 голосов
/ 13 июня 2019

Вы можете сгруппировать по StudentId и выбрать словарь для каждой группы, чтобы получить название теста и оценку:

var query = db.StudentsWork.Include(p => p.StudentId)
.Include(p => p.CourseId)
.Include(p => p.TestId)
.GroupBy(c => c.StudentId)
.Select(g => new
{
    StudentName=g.Key.Name,

    TestGrade = g.ToDictionary(t => t.TestId.Name, t => t.Grade)
});

var result = query.ToList();

enter image description here

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...