加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 如何使用动态LINQ进行求和

发布时间:2020-12-15 08:13:05 所属栏目:百科 来源:网络整理
导读:我有以下与 dynamic linq library一起出色的工作: string where = "Price 5";string orderby = "BookID ASC";IQueryableT MyDataQueryable = _DataRawBase.AsQueryableT();MyDataQueryable = MyDataQueryable.Where(where).OrderBy(orderby); 现在我想查询M
我有以下与 dynamic linq library一起出色的工作:
string where = "Price < 5";
string orderby = "BookID ASC";
IQueryable<T> MyDataQueryable = _DataRawBase.AsQueryable<T>();
MyDataQueryable = MyDataQueryable.Where(where).OrderBy(orderby);

现在我想查询MyDataQueryable来做某些字段的SUM(也许是平均值).

我该怎么做?

就像是:

double mysum = MyDataQueryable.Sum("Price");

会好的…

解决方法

由于所有内容都是字符串类型,您可能需要尝试:
var myDataQueryable = _DataRawBase.AsQueryable<T>()
    .Sum("Price");

使用以下扩展方法:

public static object Sum(this IQueryable source,string member)
{
    if (source == null) throw new ArgumentNullException(nameof(source));
    if (member == null) throw new ArgumentNullException(nameof(member));

    // The most common variant of Queryable.Sum() expects a lambda.
    // Since we just have a string to a property,we need to create a
    // lambda from the string in order to pass it to the sum method.

    // Lets create a ((TSource s) => s.Price ). First up,the parameter "s":
    ParameterExpression parameter = Expression.Parameter(source.ElementType,"s");

    // Followed by accessing the Price property of "s" (s.Price):
    PropertyInfo property = source.ElementType.GetProperty(member);
    MemberExpression getter = Expression.MakeMemberAccess(parameter,property);

    // And finally,we create a lambda from that. First specifying on what
    // to execute when the lambda is called,and finally the parameters of the lambda.
    Expression selector = Expression.Lambda(getter,parameter);

    // There are a lot of Queryable.Sum() overloads with different
    // return types  (double,int,decimal,double?,int?,etc...).
    // We're going to find one that matches the type of our property.
    MethodInfo sumMethod = typeof(Queryable).GetMethods().First(
        m => m.Name == "Sum"
             && m.ReturnType == property.PropertyType
             && m.IsGenericMethod);

    // Now that we have the correct method,we need to know how to call the method.
    // Note that the Queryable.Sum<TSource>(source,selector) has a generic type,// which we haven't resolved yet. Good thing is that we can use copy the one from
    // our initial source expression.
    var genericSumMethod = sumMethod.MakeGenericMethod(new[] { source.ElementType });

    // TSource,source and selector are now all resolved. We now know how to call
    // the sum-method. We're not going to call it here,we just express how we're going
    // call it.
    var callExpression = Expression.Call(
        null,genericSumMethod,new[] {source.Expression,Expression.Quote(selector)});

    // Pass it down to the query provider. This can be a simple LinqToObject-datasource,// but also a more complex datasource (such as LinqToSql). Anyway,it knows what to
    // do.
    return source.Provider.Execute(callExpression);
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读