SQL Server 大数据量分页

1、ROW_NUMBER() OVER()方式(SQL2012以下推荐使用)

SELECT

*

FROM

( SELECT ROW_NUMBER ( ) OVER ( ORDER BY menuId ) AS RowId,* FROM sys_menu ) AS r

WHERE

RowId BETWEEN 1 AND 10

用子查询新增一列行号(ROW_NUMBER)RowId查询,比较高效的查询方式,只有在SQL Server2005或更高版本才支持。

"BETWEEN 1 AND 10" 是指查询第1到第10条数据(闭区间),在这里面需要注意的是OVER的括号里面可以写多个排序字段。

通用用法:

--pageIndex 表示指定页

--pageSize 表示每页显示的条数

SELECT

*

FROM

( SELECT ROW_NUMBER ( ) OVER ( ORDER BY 排序字段 ) AS RowId,* FROM 表名 ) AS r

WHERE

RowId BETWEEN ( ( pageIndex - 1 ) * pageSize + 1 )

AND ( pageIndex * PageSize )

2、offset fetch next方式(SQL2012及以上的版本才支持:推荐使用 )

--offset fetch next方式查询,最高效的查询方式,只有在SQL Server2012或更高版本才支持

SELECT

*

FROM

sys_menu

ORDER BY

menuId offset 0 ROWS FETCH NEXT 10 ROWS ONLY

offset 是跳过多少行, next是取接下来的多少行, 句式 offset...rows fetch next ..rows only ,注意rows和末尾的only 不要写漏掉了,并且这种方式必须要接着Order by XX 使用,不然会报错。

举例:

SELECT

*

FROM

table1 a

WHERE

1=1 and a.id = '1'

ORDER BY

a.create_time DESC offset 102080 ROWS FETCH NEXT 30 ROWS ONLY

通用用法:

--pageIndex 表示指定页

--pageSize 表示每页显示的条数

SELECT

*

FROM

表名

ORDER BY

排序字段 offset ( ( pageIndex - 1 ) * pageSize ) ROWS FETCH NEXT pageSize ROWS ONLY

3、top not in方式 (不推荐)

--查询第11-20条记录

SELECT TOP

10 menuId, *

FROM

sys_menu

WHERE

menuId NOT IN ( SELECT TOP 10 menuId FROM sys_menu )

这条语句的原理是先查询1-10条记录的ID,然后再查询ID不属于这1-10条记录的ID,并且只需要10条记录,因为每页大小就是10,这就是获取到的第11-20条记录,这是非常简单的一种写法。

另外IN语句与NOT IN语句类似,这是NOT IN的写法,但是这种写法数据量大的话效率太低。

通用用法:

--pageIndex 表示指定页

--pageSize 表示每页显示的条数

SELECT TOP

pageSize menuId, *

FROM

sys_menu

WHERE

menuId NOT IN ( SELECT TOP ( ( pageSize - 1 ) * pageIndex ) menuId FROM sys_menu )

4、通过升序与降序方式进行查询分页(不推荐)

--查询第11-20条记录

SELECT * FROM(

SELECT TOP 10 * FROM(

SELECT TOP 20 * FROM sys_menu ORDER BY menuId ASC)

AS TEMP1 ORDER BY menuId DESC)

AS TEMP2 ORDER BY menuId ASC

这条语句首先查询前20条记录,然后在倒序查询前10条记录(即倒数10条记录),这个时候就已经获取到了11-20条记录,但是他们的顺序是倒序,所以最后又进行升序排序。

通用用法:

--pageIndex 表示指定页

--pageSize 表示每页显示的条数

SELECT * FROM(

SELECT TOP pageSize * FROM(

SELECT TOP ((pageIndex - 1) * pageSize +(pageSize*2)) * FROM sys_menu ORDER BY menuId ASC)

AS TEMP1 ORDER BY menuId DESC)

AS TEMP2 ORDER BY menuId ASC

5、采用MAX(ID)或者MIN(ID)函数(不推荐)

--查询第11-20条记录

SELECT TOP 10 * FROM sys_menu WHERE menuId>

(SELECT MAX(menuId) FROM(SELECT TOP 10 menuId FROM sys_menu ORDER BY menuId) AS TEMP1) --(第10条的id)

先把第10条记录的id找出来(当然这里面是直接使用MAX()进行查找,MIN()函数的用法也是类似的),然后再对比取比第10条记录的id大的前10条记录即为我们需要的结果。这里要注意开始时的边界值调整。

通用用法:

--pageIndex 表示指定页

--pageSize 表示每页显示的条数

SELECT TOP pageSize * FROM sys_menu WHERE menuId>

(SELECT MAX(menuId) FROM(SELECT TOP ((PageIndex-1)*PageSize) menuId FROM sys_menu ORDER BY menuId) AS TEMP1) --(第10条的id)

方案1、2、5都需要依赖一个排序Id(这个Id要么是个排序列,要么是个主键)。方案3、4则效率太低,完全不推荐。

相关推荐
Absurd5875 小时前
JavaScript中模块化在游戏引擎开发中的资源调度作用
jvm·数据库·python
2301_815279525 小时前
SQL如何利用聚合函数生成业务分析指标_KPI计算基础教程
jvm·数据库·python
qq_330037995 小时前
mysql如何排查Out of memory错误_mysql内存分配调优
jvm·数据库·python
weixin_458580126 小时前
如何在 Go 中直接将 AST 编译为可执行二进制文件?
jvm·数据库·python
Highcharts.js8 小时前
Highcharts Grid 中文站正式上线:表格数据处理的全新选择
前端·javascript·数据库·表格数据·highcharts·可视化图表·企业级图表
Elastic 中国社区官方博客12 小时前
Elasticsearch:使用 Agent Builder 的 A2A 实现 - 开发者的圣诞颂歌
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
2301_8166602112 小时前
PHP怎么处理Eloquent Attribute Inference属性推断_Laravel从数据自动推导类型【操作】
jvm·数据库·python
qq_3721542313 小时前
Go 中自定义类型与基础类型的显式转换规则详解
jvm·数据库·python
_下雨天.13 小时前
NoSQL之Redis配置与优化
数据库·redis·nosql
LiAo_1996_Y14 小时前
CSS如何实现文字渐变效果_通过background-clip实现艺术字
jvm·数据库·python