存储过程分页问题,急急急急急!!!

tryhere 2006-06-26 11:24:42
我目前用这个:declare @sqlstr nvarchar(4000), --查询字符串
@pagecount int,--第N页
@pagesize int--每页行数

select @pagecount=3--第3页
,@pagesize=10--第页10条
,@sqlstr='select * from sysobjects'

set nocount on
declare @P1 int,--P1是游标的id
@rowcount int

exec sp_cursoropen @P1 output,@sqlstr,@scrollopt=1,@ccopt=1,@rowcount=@rowcount output
select @rowcount as 总行数,ceiling(1.0*@rowcount/@pagesize) as 页数,@pagecount as 当前页
set @pagecount=(@pagecount-1)*@pagesize+1
exec sp_cursorfetch @P1,16,@pagecount,@pagesize
exec sp_cursorclose @P1

可是呢,sql语句有时会超过4000个字符,怎么办???
...全文
278 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
tryhere 2006-07-07
  • 打赏
  • 举报
回复
看过各位的建议,我后来 吧 nvarchar(4000), 改成 varchar(8000),
ok!
liangpei2008 2006-06-26
  • 打赏
  • 举报
回复
可以在代码后加一个PRINT(@sqlstr) 来观察一下字符串是否被截断!
liangpei2008 2006-06-26
  • 打赏
  • 举报
回复
用字符串拼接吧!
LouisXIV 2006-06-26
  • 打赏
  • 举报
回复
你看看这个

http://blog.csdn.net/zjcxc/archive/2003/12/29/20075.aspx

34,593

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧