3

我有以下简单的数据结构。学生列表,每个学生都有一个唯一的 ID。每个学生都有一个他们注册的课程列表。课程也有唯一的 ID,但将是多个 studentCourses 列表的成员(因为每个课程都由多个学生注册)。

我正在尝试通过 studentId 和 courseId 找到特定的成绩值。我正在使用下面的 linq 查询。我对我的 linq 仍然有点动摇,想知道我写的查询是否正确?它确实可以正常工作,但是可以将其更改为更优雅/可读吗?

class Student {
    int studentId;
    string studentName;
    List<Course> studentCourses;
}

class Course {
    int courseId;
    string courseName;
    int grade;
}

List<Student> students = new List<Student>();
//populate list.                
int studentGrade = students
    .Where(c => c.studentId == 1)
    .Select(c => c.studentCourses.FirstOrDefault(a => a.courseId == 1).grade)
    .FirstOrDefault();
4

3 回答 3

4

我会使用一些查询语法:

var studentGrade = 
    (from student in students
    where student.studentId == 1
    from course in student.studentCourses
    where course.courseId == 1
    select course.grade)
        .FirstOrDefault();

如果查找的任何部分(学生/课程)失败,则序列将为空并FirstOrDefault给您一个零。

这也可以用 来完成SelectMany,这就是这些多个froms 所转换的内容。

于 2012-08-15T10:02:09.270 回答
1
int studentGrade = students
                      .Where(d=>d.studentId == 1)
                      .FirstOrDefault().studentCourses
                      .FirstOrDefault(d=>d.courseId == 1).grade;
于 2012-08-15T10:03:55.763 回答
0

如果您确定学生和课程存在,那么

int studentGrade = students
                      .FirstOrDefault(s => s.studentId == 1).studentCourses
                      .FirstOrDefault(c => c.courseId == 1).grade;

其他类似的东西

var student = students.FirstOrDefault(s => s.studentId == 1);
var course = student != null ? student.studentCourses.FirstOrDefault(c => c.courseId == 1) : null;
int studentGrade = course != null ? course.grade : -1;
于 2012-08-15T10:32:25.087 回答