Row_Number实现分页(适用SQL)

1:首先是

select ROW_NUMBER() over(order by id asc) as ‘rowNumber‘, * from table1

生成带序号的集合

2:再查询该集合的 第 1  到第 5条数据

select * from
    (select ROW_NUMBER() over(order by id asc) as ‘rowNumber‘, * from table1) as temp
    where rowNumber between 1 and 5

完整的Sql语句

declare @pagesize int; declare @pageindex int; set @pagesize = 3

set @pageindex = 1; --第一页

select * from (select ROW_NUMBER() over(order by id asc) as
‘rowNumber‘, * from table1) as temp where rowNumber between
(((@pageindex-1)*@pagesize)+1) and (@pageindex*@pagesize)

set @pageindex = 2; --第二页

select * from (select ROW_NUMBER() over(order by id asc) as
‘rowNumber‘, * from table1) as temp where rowNumber between
(((@pageindex-1)*@pagesize)+1) and (@pageindex*@pagesize)

set @pageindex = 3; --第三页

select * from (select ROW_NUMBER() over(order by id asc) as
‘rowNumber‘, * from table1) as temp where rowNumber between
(((@pageindex-1)*@pagesize)+1) and (@pageindex*@pagesize)

set @pageindex = 4;--第四页

select * from (select ROW_NUMBER() over(order by id asc) as
‘rowNumber‘, * from table1) as temp where rowNumber between
(((@pageindex-1)*@pagesize)+1) and (@pageindex*@pagesize)

下面我们来写个存储过程分页

------------------------------

Alter Procedure PagePager

@TableName varchar(80),

@File varchar(1000),---

@Where varchar(500),---带and连接

@OrderFile varchar(100), -- 排序字段

@OrderType varchar(10),--asc:顺序,desc:倒序

@PageSize varchar(10), --

@PageIndex varchar(10) --

as

if(ISNULL(@OrderFile, ‘‘) = ‘‘)

begin

set @OrderFile = ‘ID‘;

end

if(ISNULL(@OrderType,‘‘) = ‘‘)

begin

set @OrderType = ‘asc‘

end

if(ISNULL(@File,‘‘) = ‘‘)

begin

set @File = ‘*‘

end

declare @select varchar(8000)

set @select = ‘    select ‘ + @File + ‘ from     (       select
*,ROW_NUMBER() over(order by ‘ + @OrderFile + ‘  ‘+ @OrderType + ‘) as
‘‘rowNumber‘‘    from ‘ + @TableName + ‘    where 1=1 ‘ + @Where + ‘    
)  temp where  rowNumber between (((‘ + @PageIndex + ‘ - 1) * ‘ +
@PageSize + ‘)+1) and (‘ + @PageIndex + ‘*‘+ @PageSize+‘)‘

exec(@select)

时间: 2024-11-09 00:48:42

Row_Number实现分页(适用SQL)的相关文章

使用SQL Server 2005 新的语法ROW_NUMBER()进行分页的两种不同方式的性能比较

相比在SQL Server 2000 中使用的分页方式,在SQL Server 2005中使用新的语法ROW_NUMBER()来分页效率要高出很多,但是很多人在使用ROW_NUMBER()这种分页方式时,使用的方法并不正确,以下列出不正确的和正确的做法并做简单分析: 首先假设我们已经创建了如下的表和索引并初始化了100万条数据: CREATE TABLE [dbo].[Users] ( [ID] [int] IDENTITY(1,1) NOT NULL, [Name] [varchar](50)

用oracle中的Row_Number实现分页

Row_Number实现分页 1:首先是 select ROW_NUMBER() over(order by id asc) as 'rowNumber', * from table1 生成带序号的集合 2:再查询该集合的 第 1  到第 5条数据 select * from     (select ROW_NUMBER() over(order by id asc) as 'rowNumber', * from table1) as temp    where rowNumber betwee

sqlserver2005使用row_number() over分页的实现方法

sqlserver2005使用row_number() over分页的实现方法 sqlserver2005使用row_number() over分页的实现方法,需要的朋友可以参考下. 语法:ROW_NUMBER() OVER(PARTITION BY COLUMN ORDER BY COLUMN) <BR> 例子: select * from (  select *, ROW_NUMBER() OVER(Order by a.CreateTime DESC ) AS RowNumber fro

自做 数据分页,执行SQL操作数据分页,SQL 分页

WMS.Web.YZMManagement.YZMOrderControl.YZMOrderControl_List.aspx ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33        function ListGrid() {            $("#Button1").click();        } <a id="bt

数据分页处理系列之一:Oracle表数据分页检索SQL

  关于Oracle数据分页检索SQL语法,网络上比比皆是,花样繁多,本篇也是笔者本人在网络上搜寻的比较有代表性的语法,绝非本人原创,贴在这里,纯粹是为了让"数据分页专题系列"看起来稍微完整和丰满一些,故先在这里特别声明一下,以免招来骂声一片! 先介绍两个比较有代表性的数据分页检索SQL实例. 无ORDER BY排序的写法.(效率最高) (经过测试,此方法成本最低,只嵌套一层,速度最快!即使检索的数据量再大,也几乎不受影响,速度依然!) SELECT * FROM (SELECT RO

jqgrid使用sql row_number进行分页

背景 系统中使用了jqgrid的展示,现在要处理10w+的数据量 现状 使用了全查询的,查询到了10w+的数据放到了datatable中,每次页面刷新需要9秒多,并且传递给另一个dll来处理一些事情.偶尔会出现StackOverFlow的异常问题,但是频率较大. 分析 现有的就有两个问题需要解决: 性能问题 StackOverFlow的异常问题 起始 性能问题经过调查,sql语句查询完成之后至少4秒钟左右,因为是全查询,所以把尽力的条件都做了,效果不明显. 然后考虑用sql server的row

SQL Server 使用ROW_NUMBER()进行分页

代码示例: WITH domain AS(SELECT ROW_NUMBER() OVER(ORDER BY ID DESC) ids,* FROM dbo.DomainInfo) SELECT * FROM domain WHERE ids BETWEEN 1 AND 20 ORDER BY CityID DESC

分页的SQL语句

sql="select * from (select row_number() over(orderby id) as num,* from table)as t where t.num>[email protected] and t.num<[email protected]"; 分页的公式 int start=(pageIndex-1)*pageSize+1; int end=pageIndex*pageSize;

各种数据库分页查询sql语句大全

在显示记录条目时往往要用到分页,一种常用的办法是利用各种数据库自带的定位接口对原始查询语句进行改写,从而只取出特定范围的某些记录.不同的数据库,查询定位接口是不一样的,下面做一汇总: 数据库 分页查询语句 说明 MySQL    "QUERY_SQL limit ?,?"            使用limit关键字,第一个"?"是起始行号, 第二个"?"是返回条目数 Oracle SELECT * FROM ( SELECT A.*, ROWNU