繁体   English   中英

如何在lambda表达式中返回不同的DataType?

[英]How can I return different DataTypes in lambda expression?

我想获得以下功能。 但是由于我必须返回不同的数据类型,因此不允许使用该方法。 在这种情况下我该怎么办?

.OrderBy(X =>
             {
                switch (OrderByColumn)
                {
                   case "":
                      return X.a.CreatedOn;
                   case "BookCategoryName":
                      return X.a.BookCategoryName;
                   case "BookCategoryDescription":
                      return X.a.BookCategoryDescription;
                }
                return X.a.CreatedOn;
             });

或任何其他建议来获得此功能?

我建议您更改逻辑以构建查询,而不要在lambda中进行这样的逻辑:

建立像之前的查询:

var query = list.Where(...);

if(OrderByColumn=="BookCategoryName")
{
   query = query.OrderBy(x=>x.a.BookCategoryName);
}
....

在末尾:

var result = query.ToList(); //for e.g.

它会根据您的需要工作并且看起来更干净

对于您当前的lambda可能返回的每种数据类型,请使用单独的块定义顺序,对于不使用该返回类型的所有选项,请返回一个常量。

暂时猜测, CreatedOn是一个DateTimeBookCategoryNameBookCategoryDescription是字符串,它类似于:

.OrderBy(X =>
             {
                switch (OrderByColumn)
                {
                   case "":
                      return X.a.CreatedOn;
                   case "BookCategoryName":
                      return new DateTime(1900,1,1);
                   case "BookCategoryDescription":
                      return new DateTime(1900,1,1);
                }
                return X.a.CreatedOn;
             })
.ThenBy(X =>
             {
                switch (OrderByColumn)
                {
                   case "":
                      return "";
                   case "BookCategoryName":
                      return X.a.BookCategoryName;
                   case "BookCategoryDescription":
                      return X.a.BookCategoryDescription;
                }
                return "";
             });

(当然,常量值可以移出为实常数或变量等,但是我想使上面的代码片段完全包含在内)

,另一个选择是将排序字段选择本身提取到一个单独的方法中,如下所示:

public IEnumerable<Data> SelectData(IEnumerable<Data> data, Func<Data, bool> predicate)
{
    return data
        .Where(predicate)
        .OrderBy(GetCurrentOrderingField);
}

private IComparable GetCurrentOrderingField(Data x)
{
    switch (OrderByColumn)
    {
        case "BookCategoryName":
            return x.a.BookCategoryName;

        case "BookCategoryDescription":
            return x.a.BookCategoryDescription;
    }

    return x.a.CreatedOn;
}

当然,这适用于实现IComparable接口的字段。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM