私はカスタムorderby拡張メソッドを作成しようとしましたが、コードは正常に機能しましたが、結果としてnull、空、またはゼロの値を最後にリストしたいのですが、誰でもその問題について助けてくれますか?
これがorderbyへの私の拡張方法です
public static IQueryable<T> OrderBy<T>(this IQueryable<T> q, string SortField, bool isAsc)
{
//var nullExpr = Expression.Constant(null, typeof(T));
var param = Expression.Parameter(typeof(T), "p");
var prop = Expression.Property(param, SortField);
var exp = Expression.Lambda(prop, param);
string method = isAsc ? "OrderBy" : "OrderByDescending";
Type[] types = new Type[] { q.ElementType, exp.Body.Type };
var mce = Expression.Call(typeof(Queryable), method, types, q.Expression, exp);
return q.Provider.CreateQuery<T>(mce);
}
前もって感謝します