[英]How to pass predicate to linq expression
给定这样的方法签名...
IEnumerable<Student> get(Func<DataRow, bool> predicate);
如何将谓词参数传递给linq表达式?
public override IEnumerable<Student> get(Func<System.Data.DataRow, bool> predicate = null) {
var students = from student in _dataSet.Tables[0].AsEnumerable()
join attendance in _dataSet.Tables[1].AsEnumerable()
on student.Field<int>("id") equals attendance.Field<int>("idStudent")
join grade in _dataSet.Tables[2].AsEnumerable()
on student.Field<int>("id") equals grade.Field<int>("idStudent")
join assignment in _dataSet.Tables[3].AsEnumerable()
on student.Field<int>("id") equals assignment.Field<int>("idStudent")
// where predicate??
// select blahblahblah
// return statement
}
由于predicate
是一个将DataRow
作为输入的函数-像where predicate(student)
一样使用它。
var students = from student in _dataSet.Tables[0].AsEnumerable()
...
where predicate == null || predicate(student)
select student
我想你要:
where predicate == null || predicate(student)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.