`
niunan
  • 浏览: 700951 次
  • 性别: Icon_minigender_1
  • 来自: 南宁
社区版块
存档分类
最新评论

SQL分页语句

    博客分类:
  • SQL
阅读更多
    比较万能的分页:
select top 每页显示的记录数 * from topic where id not in
 (select top (当前的页数-1)×每页显示的记录数 id from topic order by id desc)
 order by id desc

需要注意的是在access中不能是top 0,所以如果数据只有一页的话就得做判断了。。

SQL2005中的分页代码:
with temptbl as (
  SELECT ROW_NUMBER() OVER (ORDER BY id desc)AS Row, 
  ...
)
SELECT * FROM temptbl where Row between @startIndex and @endIndex

分享到:
评论
13 楼 jhlovett 2009-07-30  


下面的结果没有查看哦!!!~
12 楼 jhlovett 2009-07-29  
exec (@strSQL)
print @strSQL  -- 测试用,可在查询的时候看到生成的SQL语句

创建完存储过程后,怎么打印不出来捏!!!

怪啊!
11 楼 niunan 2009-07-22  
自己在网上找了一下。。发现http://hi.baidu.com/fuhengyu/blog/item/adb30aafe4df88c87cd92ae9.html
有个分页存储过程,觉得蛮简单的,弄下来在自己的机子上测试了一下,发现出错,自己更改了一下错误,改后的分页存储过程如下:
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author:		牛腩
-- Create date: 2009-07-22 12:41
-- Description:	分页,用到了ROW_NUMBER()
-- =============================================
ALTER PROCEDURE [dbo].[proc_ShowPage]
@tblName   varchar(255),       -- 表名
@strGetFields varchar(1000) = '*', -- 需要返回的列,默认*
@strOrder varchar(255)='',      -- 排序的字段名,必填
@strOrderType varchar(10)='ASC', -- 排序的方式,默认ASC
@PageSize   int = 10,          -- 页尺寸,默认10
@PageIndex int = 1,           -- 页码,默认1
@strWhere varchar(1500) = '' -- 查询条件 (注意: 不要加 where)
AS

declare @strSQL   varchar(5000)

if @strWhere !=''
set @strWhere=' where '+@strWhere

set @strSQL=
'SELECT * FROM ('+
	'SELECT ROW_NUMBER() OVER (ORDER BY '+@strOrder+' '+@strOrderType+') AS pos,'+@strGetFields+' '+
	'FROM ['+@tblName+'] '+@strWhere+
') AS sp WHERE pos BETWEEN '+str((@PageIndex-1)*@PageSize+1)+' AND '+str(@PageIndex*@PageSize)

exec (@strSQL)
print @strSQL  -- 测试用,可在查询的时候看到生成的SQL语句
10 楼 niunan 2009-03-17  
hotttoy 写道

牛腩老师给我们个demo吧。我们调试总是报错,期待牛腩老师的demo。 谢谢! 我们很想学习 支持牛腩老师!

SQL2000的存储过程的代码已经在回复中给了呀...
9 楼 hotttoy 2009-03-15  
郁闷,调试一下午,没有调试出来。能给个demo吗
谢谢
8 楼 hotttoy 2009-03-15  
牛腩老师给我们个demo吧。我们调试总是报错,期待牛腩老师的demo。
谢谢!
我们很想学习
:idea: 支持牛腩老师!
7 楼 niunan 2009-03-01  
asd300 写道

下面的代码也不行
select top 5 * from news where id not in ( select top (@currentPageIndex-1)*5  id from news order by id desc ) order by id desc


在MSSQL中的存储过程中select top @pageSize from authors这样子是不行的,下面是我写的一个MSSQL的分页存储过程,自己测试是成功了,注意我是在MSSQL中测试的。。。
获取的分页数据是pubs数据库中的authos表
USE [pubs]
GO

/****** Object:  StoredProcedure [dbo].[authors_selectByPage]    Script Date: 03/01/2009 13:38:36 ******/
SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

-- =============================================
-- Author:		牛腩
-- Create date: 20090301 13:24
-- Description:	从pubs数据库中的authors表中选择数据
--				传入选择的页数,每页显示数固定为5条
-- =============================================
CREATE PROCEDURE [dbo].[authors_selectByPage]
	@page int -- 要选择第X页的数据
AS
BEGIN
	declare @pageSize int  -- 每页显示数,固定为5条
	set @pageSize=5
	declare @sql nvarchar(1000)
	set @sql='select top '+convert(varchar(10),@pageSize)+' * from authors where au_id not in
	 (select top '+convert(varchar(20),(@page-1)*@pageSize)+' au_id from authors)'
	exec (@sql)
END

GO
6 楼 asd300 2009-02-27  
下面的代码也不行
select top 5 * from news where id not in ( select top (@currentPageIndex-1)*5  id from news order by id desc ) order by id desc
5 楼 asd300 2009-02-27  
你能写个例子吗?
我的存储过程代码是这样的,
create procedure procNewsSelectPager
@currentPageIndex int
as
begin

select top 5 * from news where id not in ( select top (@currentPageIndex-1)5  id from news order by id desc ) order by id desc
end
老是报错
服务器: 消息 170,级别 15,状态 1,过程 procNewsSelectPager,行 6
第 6 行: '(' 附近有语法错误。

4 楼 niunan 2009-01-31  
asd300 写道

select top 8(2-1) id from news order by id desc 红色部分在SQL2000里面老是报错,如果直接改成8就没问题,

中间那个符号是*,乘以...
(当前的页数-1) 乘以 每页显示的记录数

应该是select top 8*(2-1) id from news order by id desc
3 楼 asd300 2009-01-30  
select top 8(2-1) id from news order by id desc
红色部分在SQL2000里面老是报错,如果直接改成8就没问题,
2 楼 niunan 2009-01-30  
asd300 写道

比较万能的分页语句,试过不行啊,


不知道你是在哪试的,ACCESS里的话就不能是top 0...
1 楼 asd300 2009-01-29  
比较万能的分页语句,试过不行啊,

相关推荐

Global site tag (gtag.js) - Google Analytics