반성을 사용해야합니다. 당신이이 동적으로 선택한 열을 기준으로 필터링하려는 경우, 당신은 이런 식으로 뭔가를 시도 할 수 있습니다 :
string propertyName
string keyword
ParameterExpression parameter = Expression.Parameter(typeof(YourType), "x");
Expression property = Expression.Property(parameter, propertyName);
Expression target = Expression.Constant(keyword);
Expression containsMethod = Expression.Call(property, "Contains", null, target);
Expression<Func<YourType, bool>> lambda =
Expression.Lambda<Func<YourType, bool>>(containsMethod, parameter);
var companies = repository.AsQueryable().Where(lambda);
을 나는 당신이 당신이 람 바어를 생성하는 동일한 원리를 사용하여, 특정 열을 선택하면된다하려고 표현을 사용하고 선택에서 (빼기 조건)
var companies = repository.AsQueryable().Where(whatever).Select(lambda);
출처
2011-10-21 19:32:27
AJC
? 귀하의 예제에서는 할당 후 _col1을 사용하지 않습니다. 지정하십시오 ... – AJC
문자열 목록의 문자열 값을 기준으로 열 이름을 입력해야 필터링 할 수 없습니다. – Andy