LINQ 里的 OrderBy,我需要根据不同的条件使用不同的 key,怎么写比较正确(优雅)

2021-01-31 22:35:19 +08:00
 zxCoder

这样写报错了,无法推断类型。

var data=dtoData
                    .OrderBy(p => {
                        if (requestDto.OrderByTotal) {
                            return p.Total;
                        }else if (requestDto.OrderByAcNum) {
                            return p.AcNum;
                        }else if (requestDto.OrderByAcRate) {
                            return p.AcRate;
                        } else {
                            return p.ID;
                        }
                    })
1541 次点击
所在节点    C#
4 条回复
forgottencoast
2021-02-01 00:20:41 +08:00
if 要写在外面,这样写 LINQ 底层的引擎会尝试把 if 代码编译成 SQL 语句。
示例:
if (requestDto.OrderByTotal)
{
data = dtoData.OrderBy(p => p.Total);
}
...
wdv2ly
2021-02-01 07:46:59 +08:00
我猜你返回这几个参数类型不一样,导致匿名方法没办法确定返回值类型
netnr
2021-02-01 08:41:02 +08:00
用扩展,写字符串
INCerry
2021-02-04 15:59:59 +08:00
你可以这样子
var list = new List<MyClass>();
var enumerable = (IEnumerable<MyClass>) list;
if (判断条件 1)
{
enumerable = enumerable.OrderBy(c => c.Value1);
}
else if(判断条件 2)
{
enumerable = enumerable.OrderBy(c => c.Value2);
}
else if(判断条件 3)
{
enumerable = enumerable.OrderBy(c => c.Value2);
}
var result = enumerable.ToList();
当然你可以写成 switch,实际上还可以用组合表达式来做,用 Expression<Func<T, T1>>

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/750088

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX