菜单 学习猿地 - LMONKEY

VIP

开通学习猿地VIP

尊享10项VIP特权 持续新增

知识通关挑战

打卡带练!告别无效练习

接私单赚外块

VIP优先接,累计金额超百万

学习猿地私房课免费学

大厂实战课仅对VIP开放

你的一对一导师

每月可免费咨询大牛30次

领取更多软件工程师实用特权

入驻
263
0

知方可补不足~sqlserver中使用ROW_NUMBER进行的快速分页

原创
05/13 14:22
阅读数 51683

回到目录

这个在SQL2005之后最见的一种分页方式,也是Linq默认生成的执行分页的方法(skip,take),当然在性能上小数量没有问题,在数据达到百万时会很慢,这是我们要清楚的,有时我们在LINQ环境下也需要分页写SQL,这时如何去分布就成为了一个很不好处

理的问题,所以大叔还是把准备的分页代码贡献一下

DECLARE @pageSize INT ;
DECLARE @pageIndex INT ;
SET @pageSize = 
SET @pageIndex = ;
 --第二页,每页显示5条数据                      
SELECT  *
FROM    ( SELECT    ROW_NUMBER() OVER ( ORDER BY CreateDate ASC ) AS 'rowNumber' ,
                    *
          FROM      dbo.Task_Info
        ) AS temp
WHERE   rowNumber BETWEEN ( ( ( @pageIndex - 1 ) * @pageSize ) + 1 )
                  AND     ( @pageIndex * @pageSize )      

在LINQ环境下使用SQL代码如下

Db.Database.SqlQuery<FighterTaskTotalDTO>("你的代码")

结果

回到目录

发表评论

0/200
263 点赞
0 评论
收藏