微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 实体框架5执行全表扫描

我有以下代码
public List<anEntity> Get(int page,int pagesize,Func<anEntity,IComparable> orderby)
{            
    using (var ctx = new MyContext())
    {                
        return ctx.anEntity.OrderBy(orderby).Skip(pagesize * page).Take(pagesize).ToList();                    
    }           
}

当我检查我的数据库配置文件(sqlServer 2012)时,我可以看到一个可怕的全表扫描,没有任何“TOP”子句.

有趣的部分:

如果我做类似的事情,但指定一个具体的顺序:

return ctx.anEntity.OrderBy(x => x.aField).Skip(pagesize * page).Take(pagesize).ToList();

该资料显示一个美丽的“TOP”子句.

我想避免有很多方法,一种是针对每个“orderby”的可能性.任何暗示都将非常感激.

解决方法

这是因为你的orderby参数是一个函数而不是表达式.没有办法将任意函数转换为sql,因此在调用函数之前,所有数据必须位于客户端.

将参数类型更改为Expression< func< anEntity,T>>,其中T是您应该添加到Get方法的新通用参数,它将按预期工作.

当然,您将无法使用自定义的IComparable,但没有办法:自定义代码不能被翻译成sql.

原文地址:https://www.jb51.cc/csharp/92542.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐