您好,欢迎访问一九零五行业门户网

Oracle数据库查询高效分页

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,从以下的执行计划也能看出差异来。
其它类似信息

推荐信息