cAng^Er

不懂我的人 , 离不了我 , 该了解了解我 !而懂我的人 , 更离不了我 , 因为他们爱我 。

  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理 ::
  30 随笔 :: 16 文章 :: 18 评论 :: 0 Trackbacks

今天在网上看到了几个解决sql2000的分页查询方法
写在这里(没有测试)


四种方法取表里n到m条纪录:

1.
select top m * into 临时表(或表变量) from tablename order by columnname -- 将top m笔插入
set rowcount n
select * from 表变量 order by columnname desc

2.
select top n * from
(select top m * from tablename order by columnname) a
order by columnname desc

3.如果tablename里没有其他identity列,那么:
select identity(int) id0,* into #temp from tablename

取n到m条的语句为:
select * from #temp where id0 >=n and id0 <= m

如果你在执行select identity(int) id0,* into #temp from tablename这条语句的时候报错,那是因为你的DB中间的select into/bulkcopy属性没有打开要先执行:
exec sp_dboption 你的DB名字,'select into/bulkcopy',true

4.如果表里有identity属性,那么简单:
select * from tablename where identitycol between n and m
**********************************************
 *sql2000下 分页存储过程 **********************

**********************************************

SET
 QUOTED_IDENTIFIER OFF 
GO
SET ANSI_NULLS ON 
GO
--名称:分页存储过程
--
使用示例 EXEC sp_PageIndex '*',' FROM StuSources ',2,10
--
注意 
--
目前还没有对输入的参数进行严格的验证
--
默认为输入都是合法有效的

ALTER  PROC sp_PageIndex
 
@sqlSelect varchar(800--SELECT 后面 FROM 前面 的 字段 不用包含SELECT
,@sqlFrom varchar(800--FROM 后面 的 字段 包含FROM
,@countPerPage int -- 每页数据行数
,@toPage int --要转到的页码

AS

BEGIN


-- 根据每页数据行数 和 要转到的页码 得到 数据起止点
Declare @start int
Declare @end int

set @end = @countPerPage * @toPage
set @start = @countPerPage * (@toPage - 1+ 1


-- 临时表名称 可随机命名
Declare @tmpTable varchar(10)
SET @tmpTable ='#tmp'

Declare @sqlStr varchar(800)
-- 创建数据源到临时表
SELECT @sqlStr = 'SELECT Identity(int,1,1) AS RowIndex,'
SELECT @sqlStr = @sqlStr + rtrim(@sqlSelect+ ' INTO  '+ @tmpTable 
SELECT @sqlStr = @sqlStr + rtrim(@sqlFrom
-- 查询临时表 得到所需要的数据
SELECT @sqlStr = @sqlStr + ' '+'SELECT '+ rtrim(@sqlSelect+' FROM ' + @tmpTable 
SELECT @sqlStr = @sqlStr + ' WHERE  RowIndex BETWEEN ' + Convert(char,@start+ " AND " + Convert(char,@end)
-- 删除临时表
SELECT @sqlStr = @sqlStr + ' '+'DROP TABLE '+@tmpTable
EXEC (@sqlStr)


END


GO
SET QUOTED_IDENTIFIER OFF 
GO
SET ANSI_NULLS ON 
GO
posted on 2007-01-18 10:00 cAng^Er 阅读(2311) 评论(4)  编辑  收藏 所属分类: |:数 据 库:|

评论

# re: sql2000 分页查询 2007-01-18 20:49 剑事
网上有完整的存储过程可以用  回复  更多评论
  

# re: sql2000 分页查询 2009-03-17 12:22 牛腩
好是好,不过我在做的时候发现个问题..如果你是自己出钱买的空间的话,网上提供的MSSQL给你的账号都设置了权限的,不能使用EXECUTE ...所以这个存储过程如果是用于自己买的空间的话就不成了..唉...  回复  更多评论
  

# re: sql2000 分页查询 2010-01-11 09:36 smallcol
这种方式如果数据有100W条的话那不是很慢?
光insert #tmp表都要好几分钟  回复  更多评论
  

# re: sql2000 分页查询 2010-06-18 16:39 Mm
最失败的就是上面的分页。。  回复  更多评论
  


只有注册用户登录后才能发表评论。


网站导航:
博客园   IT新闻   Chat2DB   C++博客   博问