V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
zxCoder
V2EX  ›  C#

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

  •  
  •   zxCoder · 2021-01-31 22:35:19 +08:00 · 1511 次点击
    这是一个创建于 1152 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

    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;
                            }
                        })
    
    4 条回复    2021-02-04 15:59:59 +08:00
    forgottencoast
        1
    forgottencoast  
       2021-02-01 00:20:41 +08:00
    if 要写在外面,这样写 LINQ 底层的引擎会尝试把 if 代码编译成 SQL 语句。
    示例:
    if (requestDto.OrderByTotal)
    {
    data = dtoData.OrderBy(p => p.Total);
    }
    ...
    wdv2ly
        2
    wdv2ly  
       2021-02-01 07:46:59 +08:00 via Android
    我猜你返回这几个参数类型不一样,导致匿名方法没办法确定返回值类型
    netnr
        3
    netnr  
       2021-02-01 08:41:02 +08:00 via Android
    用扩展,写字符串
    INCerry
        4
    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>>
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   1028 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 30ms · UTC 19:20 · PVG 03:20 · LAX 12:20 · JFK 15:20
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.