sql 排序函数ROW_NUMBER分页返回数据

时间:2022-09-08 21:59:48

分页从数据库返回一张表的某些条数据

假设我需要查询 系统表 sys.all_columns中的数据,每次查询10条

第一次查询第1-10条数据

第二次查询第11-20条数据

第三次查询第21-30条数据

......以此类推

于是我想到了sqlserver的ROW_NUMBER()排序函数,可以根据排序的字段返回行号

详细请查看微软官方文档 https://docs.microsoft.com/zh-cn/sql/t-sql/functions/row-number-transact-sql?view=sql-server-2017

ROW_NUMBER()语法

ROW_NUMBER ( )
OVER ( [ PARTITION BY value_expression , ... [ n ] ] order_by_clause )

参数

PARTITION BY value_expression
将 FROM 子句生成的结果集划分为应用 ROW_NUMBER 函数的分区。 value_expression 指定对结果集进行分区所依据的列。 如果未指定 PARTITION BY,则此函数将查询结果集的所有行视为单个组。 有关详细信息,请参阅 OVER 子句 (Transact-SQL)。 order_by_clause
ORDER BY 子句可确定在特定分区中为行分配唯一 ROW_NUMBER 的顺序。 它是必需的。 有关详细信息,请参阅 OVER 子句 (Transact-SQL)。

返回类型

bigint

分页示例:

查询第一页时

DECLARE @Page_index INT --页数
DECLARE @Page_size INT --每页条数 SET @Page_index=1
SET @Page_size=10 DECLARE @BNUN INT --开始条数
DECLARE @ENUM INT --结束条数 SET @BNUN=(@Page_index-1) * @Page_size
SET @ENUM=@Page_index * @Page_size --排序取表中第几条到第几条数据
SELECT * FROM (SELECT ROW_NUMBER() OVER (ORDER BY name) AS RowNum, *
FROM (SELECT * FROM master.sys.all_columns) AS T ) AS N WHERE RowNum > @BNUN And RowNum <= @ENUM
--返回总条数
SELECT COUNT(1) FROM (SELECT * FROM master.sys.all_columns) AS t

查询结果

sql 排序函数ROW_NUMBER分页返回数据

查询第n页时

DECLARE @Page_index INT --页数
DECLARE @Page_size INT --每页条数 SET @Page_index=n
SET @Page_size=10 DECLARE @BNUN INT --开始条数
DECLARE @ENUM INT --结束条数 SET @BNUN=(@Page_index-1) * @Page_size
SET @ENUM=@Page_index * @Page_size --排序取表中第几条到第几条数据
SELECT * FROM (SELECT ROW_NUMBER() OVER (ORDER BY name) AS RowNum, *
FROM (SELECT * FROM master.sys.all_columns) AS T ) AS N WHERE RowNum > @BNUN And RowNum <= @ENUM
--返回总条数
SELECT COUNT(1) FROM (SELECT * FROM master.sys.all_columns) AS t

sql 排序函数ROW_NUMBER分页返回数据的更多相关文章

  1. SQL Server排序函数row&lowbar;number和rank的区别

    SQL Server排序函数row_number和rank的区别 直接看测试结果 declare @table table(name varchar(100),amount int, memo var ...

  2. 腾讯云图片鉴黄集成到C&num; SQL Server 怎么在分页获取数据的同时获取到总记录数 sqlserver 操作数据表语句模板 &period;NET MVC后台发送post请求 百度api查询多个地址的经纬度的问题 try&lbrace;&rcub;里有一个 return 语句,那么紧跟在这个 try 后的 finally &lbrace;&rcub;里的 code 会 不会被执行,什么时候被执行,在 return 前还是后&quest; js获取某个日期

    腾讯云图片鉴黄集成到C#   官方文档:https://cloud.tencent.com/document/product/641/12422 请求官方API及签名的生成代码如下: public c ...

  3. mssql sqlserver 分组排序函数row&lowbar;number、rank、dense&lowbar;rank用法简介及说明

    在实际的项目开发中,我们经常使用分组函数,对组内数据进行群组后,然后进行组内排序:如:1:取出一个客户一段时间内,最大订单数的行记录2: 取出一个客户一段时间内,最后一次销售记录的行记录——————— ...

  4. IBatis&period;Net使用总结(三)-- IBatis实现分页返回数据和总数

    IBatis 分页,这里没有使用其他插件,只使用最原始的方法. 输入参数: int currentPage 当前页 int  pageSize 每页大小 Hashtable findCondition ...

  5. SQL Server 怎么在分页获取数据的同时获取到总记录数

    SQL Server 获取数据的总记录数,有两种方式: 1.先分页获取数据,然后再查询一遍数据库获取到总数量 2.使用count(1) over()获取总记录数量 SELECT * FROM ( SE ...

  6. SQL Server 排序函数 ROW&lowbar;NUMBER和RANK 用法总结

    下面的例子和SQL语句均在SQL Server 2008环境下运行通过,使用SQL Server自带的AdventureWorks数据库. 转载请注明此文原创自 CSDN TJVictor的专栏:ht ...

  7. row&lowbar;number&lpar;&rpar;分页返回结果顺序不确定

    之前通过row_number()实现分页查询时: select top [PageSize] * from ( select row_number() over (order by id desc) ...

  8. Sql Server函数全解&lt&semi;三&gt&semi;数据类型转换函数和文本图像函数

    阅读目录 一:数据类型转换函数 二:文本和图像函数 一:数据类型转换函数 在同时处理不同数据类型的值时,SQL Server一般会自动进行隐士类型转换.对于数据类型相近的值是有效的,比如int和flo ...

  9. Sql Server函数全解&lpar;三&rpar;数据类型转换函数和文本图像函数

    一:数据类型转换函数 在同时处理不同数据类型的值时,SQL Server一般会自动进行隐士类型转换.对于数据类型相近的值是有效的,比如int和float,但是对于其它数据类型,例如整型和字符类型,隐士 ...

随机推荐

  1. c&num;实现远程操作svn

    /// <summary> /// 本地svn服务器地址 /// </summary> private static string localSVN = Configurati ...

  2. JVM&sol;JDK&sol;JRE&sol;IDE—区别(很经典)

    转载于 http://blog.csdn.net/jojo52013145/article/details/5801916 只是为了学习,转载没有别的目地,就是爱copy,copy一点点,进步一点点 ...

  3. 003医疗项目-关于&lt&semi;context&colon;property-placeholder location&equals;&quot&semi;classpath&colon;db&period;properties&quot&semi;&sol;&gt&semi;的问题

    项目结构如下:

  4. JavaScript入门&lpar;4&rpar;

    一.JS能做什么? 1.增强页面动态效果(如:下拉菜单.图片轮播.信息滚动等) 2.实现页面与用户之间的实时.动态交互(如:用户注册.登录验证等) 什么是变量?http://www.cnblogs.c ...

  5. String、StringBuffer和StringBuilder——个人学习

    1.首先说一下他们的名称区别: String——字符串常量,StringBuffer——字符串变量(线程安全),StringBuilder——字符串变量(非线程安全) 从名称就可以很明显的看出他们的基 ...

  6. 【HDOJ】1829 A Bug&&num;39&semi;s Life

    并查集变型.题意就是x与y是互斥的,下列是否数据是否可保证x-y是否均为互斥. #include <cstdio> #include <cstring> #define MAX ...

  7. JAVA采用JDBC连接操作数据库详解

    JDBC连接数据库概述 一.JDBC基础知识 JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供 ...

  8. 开发手记:Linux下更改Oracle表空间大小

    问题:同事反馈我们的测试环境数据库执行SQL和编译PKG非常慢,猜测可能是我们的测试环境数据库的表空间满了,但是我不知道数据库DBA的用户和密码. 步骤1:查看表空间占用情况 SELECT UPPER ...

  9. 关于Zookeeper选举机制

    zookeeper集群 配置多个实例共同构成一个集群对外提供服务以达到水平扩展的目的,每个服务器上的数据是相同的,每一个服务器均可以对外提供读和写的服务,这点和redis是相同的,即对客户端来讲每个服 ...

  10. Maven发布war包到Tomcat

    一.修改Tomcat下配置文件tomcat-users.xml,然后启动 <role rolename="manager-gui"/> <role rolenam ...