linq提供了skip和take的api可以用于分页,由于使用的是entity framework,在好奇的驱使下用efprofiler查看生成的sql,才知道这样以下分页更好。 主要就是使用了row_numer()over()这样的分析函数,可以直接找到那第5000行开始的地方,然后在取出30行就行
linq提供了skip和take的api可以用于分页,由于使用的是entity framework,在好奇的驱使下用efprofiler查看生成的sql,才知道这样以下分页更好。 主要就是使用了row_numer()over()这样的分析函数,可以直接找到那第5000行开始的地方,然后在取出30行就行了。
select * from (select * from (select t.*, row_number() over(order by null) as row_number from yz_bingrenyz t) p where p.row_number > 5000 ) q where rownum
比较分析:
本机测试前者耗时1.3s,后者仅0.25s,从以下的执行计划也能看出差异来。