注册 登录
编程论坛 SQL Server论坛

分页显示数据,10条记录一个单位,怎么查询

pzf007 发布于 2006-07-30 13:11, 1781 次点击
0-10  10-20。。。。。。。。。。。。。
10 回复
#2
林升2006-07-30 17:42

这个问题还没看见过,不知道怎么搞定,顶上去看有人知道没

#3
LouisXIV2006-07-30 20:55

1.
CREATE PROCEDURE sp_mypager(@sqlstr nvarchar(4000),@Pagecount int, @pagesize int )

-- @slqstr :查询字符串
-- @pagecount 第N 页
--@ pggesize 每页行数


as
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

GO


2.
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[sp_PageView]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
drop procedure [dbo].[sp_PageView]
GO

/*--利用SQL未公开的存储过程实现分页

方法简单且效率高,已知的问题就是要多返回一个空的记录集

解决的方法是在前台调用时,用 set recordset=recordset.nextrecordset
的方法跳过第一个记录集

此方法由J9988提供,我只是将它改成了方便调用的存储过程

--邹建 2004.05(引用请保留此信息)--*/

/*--调用示例

declare @PageCount int
exec sp_PageView
@sql='select * from sysobjects',
@PageCurrent=2,
@PageCount=@PageCount out
SELECT @PageCount
--*/
CREATE PROC sp_PageView
@sql ntext, --要执行的sql语句
@PageCurrent int=1, --要显示的页码
@PageSize int=10, --每页的大小
@PageCount int OUTPUT --总页数
AS
SET NOCOUNT ON
DECLARE @p1 int
--初始化分页游标
EXEC sp_cursoropen
@cursor=@p1 OUTPUT,
@stmt=@sql,
@scrollopt=1,
@ccopt=1,
@rowcount=@PageCount OUTPUT

--计算总页数
IF ISNULL(@PageSize,0)<1
SET @PageSize=10
SET @PageCount=(@PageCount+@PageSize-1)/@PageSize
IF ISNULL(@PageCurrent,0)<1 OR ISNULL(@PageCurrent,0)>@PageCount
SET @PageCurrent=1
ELSE
SET @PageCurrent=(@PageCurrent-1)*@PageSize+1

--显示指定页的数据
EXEC sp_cursorfetch @p1,16,@PageCurrent,@PageSize

--关闭分页游标
EXEC sp_cursorclose @p1
GO


#4
潇洒老乌龟2006-07-30 23:00
强人.
#5
chaoloveting2006-08-05 00:51
噢,看不懂,但顶一下.
#6
nxcgh20062006-09-22 11:16
版主的確是強者!!!
在下佩服!
努力學習中。。。。

望能幫助後者。。。。。

這個問題要先建立一下存儲過程才可解決哦
#7
卜酷塔2006-09-22 11:18
如果是用sql来完成的化可能效率会低一点,如果是借助第三方变成语言的化,更能体现速度!
#8
小水滴2006-09-22 12:28
把分页的操作放在前台处理是不是更方便
#9
棉花糖ONE2006-10-21 10:03
请3楼的斑竹稍微给代码做个解释吧,初学者不太理解
#10
cjd06592006-10-21 17:43
嗯,牛人出现了,佩服佩服
#11
梓风2006-10-28 10:10
C#代码
//自定义分页
private MyDataGrid_Page(object sender,DataGridPageChangedEventArgs e)
{
int startIndex;
startIndex = DataGrid1.CurrentPageIndex * DataGrid1.PageSize;
DataGrid1.CurrentPageIndex = e.NewPageIndex;
数据绑定;
}
private PagerButtonClick(object sender,EventArgs e)
{
string arg;
arg=sender.CommandArgument;
Switch(arg)
{
case "next" :
if(DG_Unit.CurrentPageIndex<(DG_Unit.PageCount-1))
{
DG_Unit.CurrentPageIndex += 1;
}
case "prev" :
If (DG_Unit.CurrentPageIndex > 0)
{
DG_Unit.CurrentPageIndex -= 1;
}
case "lase" :
{
DG_Unit.CurrentPageIndex = (DG_Unit.PageCount - 1)
}
case else
{
DG_Unit.CurrentPageIndex = System.Convert.ToInt32(arg);
}
}
}

页面上定义四个LinkButton
btnFirst,btnPrev,btnNext,btnLast
在Html视图中加入

<asp:linkbutton id="btnPrev" onclick="PagerButtonClick" runat="server" CssClass="black_font_12"
CommandArgument="prev"></asp:linkbutton><FONT face="宋体">|</FONT><asp:linkbutton id="btnNext" onclick="PagerButtonClick" runat="server" CssClass="black_font_12"
CommandArgument="next"></asp:linkbutton><FONT face="宋体">|</FONT><asp:linkbutton id="btnLast" onclick="PagerButtonClick" runat="server" CssClass="black_font_12"
CommandArgument="last"></asp:linkbutton><FONT face="宋体">]

DataGrid 定义是加入(Html)
OnPageIndexChanged="MyDataGrid_Page"
1