-2

我想要 mvc Linq 中的 In 运算符。

像这样的 sql(stud_ID 是 int,主键和自动增量):

select * from student where stud_ID in (1,4,6,10,5);

我怎样才能适应linq这个sql?

喜欢

List<int> nl = new List<int>();
nl.add(1);
nl.add(4);
nl.add(6);
nl.add(10);
nl.add(5);
List<student> students = db.student.where(a => a.stud_ID.In(nl)).toList();
//this code is fitting from my mind :D

或其他情况

List<student> st = db.studentOrderBy(x => Guid.NewGuid()).Take(5); //only for create auto list student type
List<student> students = db.student.where(
    a => a.stud_ID.In(st.Select(b => b.stud_ID).toList())
).toList(); //again fitting

我可以这个

List<student> students = new List<student>();
foreach(var item in nl)
{
    students.add(db.student.where(a => a.stud_ID == item).First());
}

但我不想使用 for 或 foreach 或 do-while 或 while :D

4

2 回答 2

0

尝试这个:

List<student> students = db.student.where(a => nl.Contains(a.Stud_ID)).toList();

这将检查学生 ID 是否存在于 List 中nl。如果是这样,学生将在结果中返回。

如果我理解正确,您的第二个要求是不同的。您有两个学生集合,并且想知道哪些学生也在st.

var intersectedList = students.Intersect(st);
于 2014-03-24T09:26:45.020 回答
-1

尝试这个

List<student> students = db.student.Where<student>(a =>  nl.Contains(a.stud_ID)).ToList<student>();
于 2014-03-24T12:58:18.910 回答