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

c# – 如何将表达式传递给LINQ查询?

发布时间:2020-12-15 23:31:00 所属栏目:百科 来源:网络整理
导读:我可以将Expression传递给LINQ Select()方法: public IQueryableT GetInfo(long limit,ExpressionFuncMyType,T selector){ return DbSet.Where(t = t.id limit).Select(selector)} 如何使用LINQ样式的查询来做同样的事情? public IQueryableT GetInfo(long
我可以将Expression传递给LINQ Select()方法:

public IQueryable<T> GetInfo(long limit,Expression<Func<MyType,T>> selector)
{
    return DbSet.Where(t => t.id < limit).Select(selector)
}

如何使用LINQ样式的查询来做同样的事情?

public IQueryable<T> GetInfo(long limit,T>> selector)
{
    var result = from t in DbSet
                 where t.id < limit
                 select selector(t) // doesn't work
    return result
}

解决方法

那么你可以使用:

var result = (from t in DbSet
             where t.id < limit
             select t).Select(selector);

…但你不能只在查询表达式中使用选择器,因为它隐含地包装了你不想要的额外层.

目前尚不清楚为什么你想在这里使用查询表达式,请注意 – 我强烈建议你对这两种LINQ样式感到满意并使用当时更合适的东西 – 在这种情况下你是原始样式码.

(编辑:李大同)

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

    推荐文章
      热点阅读