这里也提出了类似的问题,但没有一个符合我的需要.
我做了测试用例,看看哪个更快.但我觉得我的 linq代码仍然很慢.如何构建 linq代码以获得更快的性能?

其他人说使用double .Tolist()会导致操作变慢,当我测试它时,它表明它比任何其他测试都快.

测试:

Preparation
---------------------------------------------------------------
return Properties of UserInfo(userinf,true){
    UserID = userinf.UserID;
    FirstName = userinf.user.FirstName;
    MiddleName = userinf.user.MiddleName;
    LastName = userinf.user.LastName;
    LoginID = userinf.user.LoginID;
    Birthday = userinf.Birthday;
}

skip = 0;
take = 100;

total table records = 304;

Linq to Entity Framework

提琴手:v2.4.0.0

https://127.0.0.1/..../RetrieveUserInfo?skip=0&take=100
{
    "client":{
        "SessionID":"5433ab64-7e0d-444f-b886-a901ea9a0601"
    },"session":{
        "SessionID":"35b75daa-25ad-45a4-9f99-0e69ec3b66a4"
    }
}
//Test 1
//1) 00:00:15.3068755 -- Attempt1
//2) 00:00:13.8207905 -- Attempt2
//3) 00:00:16.2489294 -- Attempt3

var list = (from usr in dbase.userinfoes
            select usr).OrderBy(i => i.UserID).Skip(skip).Take(take).ToList();

userlist = (from i in list
            select new UserInfo(i,true)).ToList();


///Test 2
//1) 00:00:15.3908803
//2) 00:00:14.8818512
//3) 00:00:19.4761140

var list = (from usr in dbase.userinfoes.AsEnumerable().OrderBy(i => i.UserID).Skip(skip).Take(take).ToList()
            select new UserInfo(usr,true)).ToList();


//Test 3
//1) 00:00:30.1937270
//2) 00:00:24.1003784
//3) 00:00:28.8806519

var list = dbase.userinfoes.OrderBy(i => i.UserID).Skip(skip).Take(take).ToList();
userlist = (from i in list select new UserInfo(i,true)).ToList();


//Test 4
//1) 00:00:57.2652754
//2) 00:00:54.4051118
//3) 00:00:55.3251644

var list = (from usr in dbase.userinfoes
            select usr).ToList();

userlist = (from i in list
            select new UserInfo(i,true)).OrderBy(i => i.UserID).Skip(skip).Take(take).ToList();


//Test 5
//1) 00:01:06.8378229
//2) 00:01:01.2845053
//3) 00:00:55.0721499

var list = from usr in dbase.userinfoes
           select usr;

userlist = (from i in list.AsEnumerable()
            select new UserInfo(i,true)).OrderBy(i => i.UserID).Skip(skip).Take(take).ToList();


// Test 6
// VERY LONG. It tooks all records first and construct UserInfo one by one before doing the skip and take

var list = (from usr in dbase.userinfoes.AsEnumerable()
            select new UserInfo(usr,true)).OrderBy(i => i.UserID).Skip(skip).Take(take).ToList();


//Test 7
// VERY LONG. It tooks all records first and construct UserInfo one by one before doing the skip and take

var list = from usr in dbase.userinfoes.AsEnumerable()
           select new UserInfo(usr);

适合快速搜索的代码.感谢casperOne指出,在服务器上执行的排序,跳过和取得更快.

这是最终的代码:

var list = (from usr in dbase.userinfoes
                .OrderBy(i => i.UserID)
                .Skip(skip)
                .Take(take)
                .AsEnumerable()
            select new UserInfo(usr,true)).ToList();   

1) 00:00:10.9210513
2) 00:00:10.8270973
3) 00:00:10.8250151

感谢Richard Neil Ilagan的最终代码.

解决方法

这就是为什么每个人都表现得如此以及为什么你看到你所看到的:

测试1:

///Test 2
//1) 00:00:15.3068755 -- Attempt1
//2) 00:00:13.8207905 -- Attempt2
//3) 00:00:16.2489294 -- Attempt3

var list = (from usr in dbase.userinfoes
            select usr).OrderBy(i => i.UserID).Skip(skip).Take(take).ToList();

userlist = (from i in list
            select new UserInfo(i,true)).ToList();

这绝对是最快的.它是最快的,因为订购,跳过和取消都在服务器上执行.因为你可能有索引,所以服务器很强大(功能强大)等等.它可以比你在客户端实现整个集合然后在那里执行操作更快地处理这些操作.

UserInfo仅在后处理列表上构建.

测试2:

///Test 2
//1) 00:00:15.3908803
//2) 00:00:14.8818512
//3) 00:00:19.4761140

var list = (
    from usr in dbase.userinfoes.AsEnumerable().
        OrderBy(i => i.UserID).Skip(skip).Take(take).ToList()
    select new UserInfo(usr,true)
).ToList();

这应该具有与测试7相同的性能影响;对AsEnumerable的调用强制所有后续操作都在内存中执行(对OrderBy的调用将要求您在订购之前实现所有实例).

这有点像异常.我很想知道发送到服务器的sql是什么(假设您正在使用sql服务器或一些基于sql的后端),以确保它正在选择所有记录.

UserInfo仅在后处理列表上构建.

测试3:

//Test 3
//1) 00:00:30.1937270
//2) 00:00:24.1003784
//3) 00:00:28.8806519

var list = dbase.userinfoes.OrderBy(i => i.UserID).
    Skip(skip).Take(take).ToList();
userlist = (from i in list select new UserInfo(i,true)).ToList();

同样,order by,skip和take正在服务器上进行.你实现了两次列表(你有两次ToList调用),这是我可以看到的开销的唯一解释.

UserInfo仅在后处理列表上构建.

测试4:

//Test 4
//1) 00:00:57.2652754
//2) 00:00:54.4051118
//3) 00:00:55.3251644

var list = (from usr in dbase.userinfoes
            select usr).ToList();

userlist = (from i in list select new UserInfo(i,true)).
    OrderBy(i => i.UserID).Skip(skip).Take(take).ToList();

你现在正在内存中实现整个列表,所以现在有更多的开销.

UserInfo在预处理列表上构建.

测试5:

//Test 5
//1) 00:01:06.8378229
//2) 00:01:01.2845053
//3) 00:00:55.0721499

var list = from usr in dbase.userinfoes
           select usr;

userlist = (from i in list.AsEnumerable()
            select new UserInfo(i,true)).
    OrderBy(i => i.UserID).Skip(skip).Take(take).ToList();

与测试二相同,您在客户端执行所有操作.

UserInfo在预处理列表上构建.

测试6:

// Test 6
// VERY LONG. It tooks all records first and construct 
// UserInfo one by one before doing the skip and take

var list = (from usr in dbase.userinfoes.AsEnumerable()
            select new UserInfo(usr,true)).
    OrderBy(i => i.UserID).Skip(skip).Take(take).ToList();

UserInfo在预处理列表上构建.

再次,在客户端执行所有操作.

// Test 7
// VERY LONG. It tooks all records first and construct 
// UserInfo one by one before doing the skip and take

var list = from usr in dbase.userinfoes.AsEnumerable()
           select new UserInfo(usr);

再次,在客户端执行所有操作.

UserInfo在预处理列表上构建.

我在所有这些测试中都注意到了一个区别,那就是你调用UserInfo实例的构造函数的地方.在性能良好的地方,你推迟尽可能晚地构建UserInfo的实例(在执行命令,执行,跳过操作之后),而当性能不好时,你需要预先构建UserInfo实例,在进行这些操作之前(通常会对UserInfo构造函数进行更多调用).

也就是说,似乎您的性能问题可能存在于UserInfo类的构造函数中,而不是LINQ中.通常,当您让IQueryable<T>提供程序对基础数据源执行操作时,通常比在客户端的内存中执行这些操作更快.

虽然没有看到构造函数代码,但这是不可能的,但是你的数字肯定表明问题存在于那里,而不是在LINQ中.

c# – 构建linq查询以获得最快性能的正确方法?的更多相关文章

  1. angularJs中orderBy筛选以及filter过滤数据的方法

    今天小编就为大家分享一篇angularJs中orderBy筛选以及filter过滤数据的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

  2. 浅谈laravel-admin的sortable和orderby使用问题

    今天小编就为大家分享一篇浅谈laravel-admin的sortable和orderby使用问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

  3. angular.js实现列表orderby排序的方法

    今天小编就为大家分享一篇angular.js实现列表orderby排序的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

  4. 如何在c中使用Linq读取Json文件#

    我有下面的Json文件,我需要获取“rec”的role_to_secrets,然后我应该为“prod”环境获取各自的secret值。

  5. FirstOrDefault正在生成异常System.NullReferenceException

    所以我有一个文档字段,里面有其他对象,我需要这个值。如果对象或值为空,并且字符串为空,我该怎么办?

  6. 如何遍历列表以构建Linq查询

    我有以下工作查询:我想替换Where(x=>x.Value>10&&x.Value

  7. php – Yii2:如何在Find()的orderby()中添加两个字段

    如何在find()方法中添加多个字段进行排序?我试过如下但它在查询中引发错误.由yii2生成的OrderbyQuery是:ORDERBY0,1关于documentation:

  8. php – 在Laravel 5中按行和限制结果排序

    你应该使用Fulls::orderBy(..)–>take–>get()代替.

  9. php – SQL:在给定ID的where子句中查找下一行

    任何想法也欢迎.目前正在使用此SQL查询,如果我按强度列排序,则会遇到问题,因为存在重复值我的PHP代码您需要引用当前记录,然后根据已排序的列逐步查找下一条记录.下面的示例假定它已排序第一:下一步:(确保将CURR.ID=6和AND-OR与适当的括号分开!)下面是一份工作样本如果current是ID=6的行,则可以使用检索下一条记录

  10. php – 如何在pdo-&gt; query中添加变量值

    我想升级我的当前代码,这是经常用PDO注入的sql.目前我一直坚持在PDO查询中使用变量.如果我有这样的两个论点我有这样的查询PDO在查询ORDERBY的最后一行报告错误当我用这些线替换“ORDERBYDateDESCLIMIT3,3”);一切正常.那么如何在PDO::query中添加变量值呢?更新:感谢回答,我已经像这样更新了我的代码但是发生了错误:Fatalerror:Uncaughtexce

随机推荐

  1. c# – (wpf)Application.Current.Resources vs FindResource

    所以,我正在使用C#中的WPF创建一个GUI.它看起来像这样:它现在还没有完成.这两行是我尝试制作一种数据表,它们在XAML中是硬编码的.现在,我正在C#中实现添加新的水果按钮功能.我在XAML中有以下样式来控制行的背景图像应该是什么样子:因此,在代码中,我为每列col0,col1和col2创建一个图像,如果我使用以下代码,它添加了一个如下所示的新行:如你所见,它不太正确……为什么一个似乎忽略了一些属性而另一个没有?

  2. c# – 绑定DataGridTemplateColumn

    似乎我已经打了个墙,试图在DataGrid上使用DataTemplates.我想要做的是使用一个模板来显示每个单元格的两行文本.但是似乎无法以任何方式绑定列.以下代码希望显示我想做的事情.注意每个列的绑定:模板列没有这样的东西,因此,这个xaml不可能工作.我注定要将整个DataTemplate复制到每个列,只是对每个副本都有不同的约束?解决方法我不完全确定你想要做什么,但如果您需要获取整行的DataContext,可以使用RelativeSource绑定来移动视觉树.像这样:

  3. c# – 学习设计模式的资源

    最近我来到了这个设计模式的概念,并对此感到非常热情.你能建议一些帮助我深入设计模式的资源吗?

  4. c# – 是否有支持嵌入HTML页面的跨操作系统GUI框架?

    我想开发一个桌面应用程序来使用跨系统,是否有一个GUI框架,允许我为所有3个平台编写一次代码,并具有完全可脚本化的嵌入式Web组件?我需要它有一个API来在应用程序和网页之间进行交流.我知道C#,JavaScript和一些python.解决方法Qt有这样的事情QWebView.

  5. c# – 通过字符串在对象图中查找属性

    我试图使用任意字符串访问嵌套类结构的各个部分.给出以下(设计的)类:我想要从Person对象的一个实例的“PersonsAddress.HousePhone.Number”获取对象.目前我正在使用反思来做一些简单的递归查找,但是我希望有一些忍者有更好的想法.作为参考,这里是我开发的(crappy)方法:解决方法您可以简单地使用标准的.NETDataBinder.EvalMethod,像这样:

  6. c# – 文件下载后更新页面

    FamilyID=0a391abd-25c1-4fc0-919f-b21f31ab88b7&displaylang=en&pf=true它呈现该页面,然后使用以下元刷新标签来实际向用户提供要下载的文件:你可能需要在你的应用程序中做类似的事情.但是,如果您真的有兴趣在文件完全下载后执行某些操作,那么您的运气不佳,因为没有任何事件可以与浏览器进行通信.执行此操作的唯一方法是上传附件时使用的AJAXupload.

  7. c# – 如何在每个机器应用程序中实现单个实例?

    我必须限制我的.net4WPF应用程序,以便每台机器只能运行一次.请注意,我说每个机器,而不是每个会话.我使用一个简单的互斥体实现单实例应用程序,直到现在,但不幸的是,这样一个互斥是每个会话.有没有办法创建机器互连,还是有其他解决方案来实现每个机器应用程序的单个实例?

  8. c# – WCF和多个主机头

    我的雇主网站有多个主机名,都是同一个服务器,我们只是显示不同的皮肤来进行品牌宣传.不幸的是,在这种情况下,WCF似乎不能很好地工作.我试过overridingthedefaulthostwithacustomhostfactory.这不是一个可以接受的解决方案,因为它需要从所有主机工作,而不仅仅是1.我也看过thisblogpost,但是我无法让它工作,或者不是为了解决我的问题.我得到的错误是“这

  9. c# – ASP.NET MVC模型绑定与表单元素名称中的虚线

    我一直在搜索互联网,试图找到一种方式来容纳我的表单元素的破折号到ASP.NET的控制器在MVC2,3或甚至4中的默认模型绑定行为.作为一名前端开发人员,我更喜欢在我的CSS中使用camelCase或下划线进行破折号.在我的标记中,我想要做的是这样的:在控制器中,我会传入一个C#对象,看起来像这样:有没有办法通过一些正则表达式或其他行为来扩展Controller类来适应这种情况?我讨厌这样的事实,我必须这样做:甚至这个:思考?

  10. c# – 用户界面设计工具

    我正在寻找一个用户界面设计工具来显示文档中可能的GUI.我不能生成代码.我知道MicrosoftVisio提供了一个功能.但有什么办法吗?您使用哪种软件可视化GUI?

返回
顶部