public static IQueryable<TResult> ApplySortFilter<T, TResult>(this IQueryable<T> query, string columnName)
where T : EntityObject
{
var param = Expression.Parameter(typeof(T), "o");
var body = Expression.PropertyOrField(param,columnName);
var sortExpression = Expression.Lambda(body, param);
return query.OrderBy(sortExpression);
}
เนื่องจากประเภทของ OrderBy ไม่ได้อนุมานจาก sortExpression ฉันต้องระบุสิ่งนี้ในขณะทำงาน:
var sortExpression = Expression.Lambda<T, TSortColumn>(body, param);
หรือ
return query.OrderBy<T, TSortColumn>(sortExpression);
ฉันไม่คิดว่าจะเป็นไปได้อย่างไรก็ตามเนื่องจาก TSortColumn สามารถกำหนดได้ในระหว่างรันไทม์เท่านั้น
มีวิธีแก้ปัญหานี้หรือไม่?