求一个sql存储过程分页。支持多表联合查询,模糊查询!

最好详细点,要不小弟看不懂!没分了!... 最好详细点,要不小弟看不懂!没分了! 展开
 我来答
匿名用户
2013-05-15
展开全部
可以加个游标 使用更方便

@PageCount bigint output,--总页数
@Pages bigint output --当前页
as
if @Pages<=0 --判断页数
set @Pages=1
declare @指针定位 bigint
set @指针定位=9*(@Pages-1)--这个是每页10条

declare @hid bigint,--获取定位Id 主要是用自增值判断的
@余数 bigint--存余数 这个余数是 记录数/10 余下的数

select @PageCount=count(*) from [表] where [Id] = @Id
set @余数=@PageCount%10 --这里的@PageCount 是记录总数
if @余数>0
set @PageCount=@PageCount/10+1 --这里的@PageCount是总页数
else
set @PageCount=@PageCount/5 --这里的@PageCount是总页数
if @Pages>@PageCount --@Pages是当前页
set @Pages=@PageCount

declare mycur scroll cursor for
select [Id] from [表] where [Id] = @Id
open mycur
fetch absolute @指针定位 from mycur into @hid --@hid获取定位Id
if @hid is null
set @hid=0

SELECT TOP 10 * --这里的10 是指 页数大小
FROM 表
WHERE (Id NOT IN --------在where后面 可以加条件 如where [列1]=2 and (Id NOT IN-----
(SELECT TOP (@hid) Id
FROM 表
ORDER BY Id))
ORDER BY Id
--上面的是我根据下面的 自己改的 我也不确定速度快否 也请高手看看 不过挺好用--

SELECT TOP 页大小 *
FROM TestTable
WHERE (ID NOT IN
(SELECT TOP (页大小*(页数-1)) id
FROM 表
ORDER BY id))
ORDER BY ID
这是我自己整理的 你仔细看看 很好用的
匿名用户
2013-05-15
展开全部
CREATE procedure [dbo].[SP_GetPagerData_2000]
(@tblName varchar (50), --数据表名
@strFields varchar (1000), --检索字段
@pagesize int, --每页记录数
@pageindex int, --当前页
@docount bit, --是否分页
@ID varchar (10), --主键名称
@strWhere varchar (4000), --检索条件(带WHERE)
@strOrder varchar (100)) --排序条件(带Order By)
as
declare @strSQL varchar(5000) -- 主语句
if(@docount=1)
begin
set @strSQL = 'SELECT COUNT(*) AS Total FROM ' + @tblName + ' ' + @strWhere
end
else
begin
IF(@pageindex = 1)
BEGIN
set @strSQL = 'SELECT TOP ' + str(@pagesize) +' '+@strFields + ' FROM ' + @tblName + ' ' + @strWhere + ' ' + @strOrder
END
ELSE
BEGIN
SET @strSQL = 'SELECT TOP '+str(@pagesize)+' '+@strFields + ' FROM ' + @tblName + ' ' + @strWhere + ' AND '+@ID+' NOT IN ('
+ 'SELECT TOP '+str(@pagesize*(@pageindex-1)) + ' '+@ID+ ' FROM ' + @tblName + ' ' + @strWhere + ' ' + @strOrder + ') ' + @strOrder
END
end
exec (@strSQL)
GO

C#双击aspnet分页控件代码:
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式