create proc pro_purinpt
@setypeid           int,//传进来一个参数
@startIndex         int, //起始页 
@endIndex           int //位置页
as
begin
declare @indextable table(id int identity(1,1),nid int)
insert into @indextable(nid) select poid from tb_purvey order by poid desc  
select * from tb_inpt inner join tb_purvey //连接一个表
on tb_inpt.userid = tb_purvey.userid
inner join tb_third 
on tb_purvey.pogenre = tb_third.thtypeid //连接二个表
inner join @indextable t on            
tb_purvey.poid = t.nid 
where tb_third.setypeid = @setypeid and t.id between @startIndex and @endIndex order by t.id 
end
----以上通过表及变量@indextable的id来进行分页--假如我通过查询出来@indextable的id的结果需要
id
1
2
4
-------在请看以下程序----但是以下程序传进去的startIndex 等于 1, endIndex 等于 3
也就是查询出来接过只有
id
1
2---id 4的数据查询不到,请大家帮帮我 应该怎么改 谢谢!
int totalOrders = dbpurclass.purinptcount(setypeid);
AspNetPager1.RecordCount = totalOrders;//总数AspNetPager1.AlwaysShow = true;
AspNetPager1.PageSize = 3;int startIndex = AspNetPager1.PageSize * (AspNetPager1.CurrentPageIndex - 1)+1;//起始页 
int endIndex = AspNetPager1.PageSize * AspNetPager1.CurrentPageIndex;         //位置页
ad = dbpurclass.purinpt(setypeid, startIndex, endIndex);DataList1.DataSource = ad;
DataList1.DataBind();

解决方案 »

  1.   

    看不懂lz的意思,and t.id between @startIndex and @endIndex order by t.id 你查的是id在1和3之间的,怎么会出来4呢?不出来很正常啊select top ' + str((@PageIndex-1)*@PageSize) + ' ['
            + @fldName + '] from [' + @tblName + '] where ' + @strWhere + ' '利用select top 来做.这个存储过程不是网上已经有很多了吗?\
    http://www.cnblogs.com/maiqi/archive/2006/05/04/391349.html
    http://www.cnblogs.com/RobotH/archive/2007/05/30/765175.html
      

  2.   

    你上面的id是临时表的id,1---3肯定没有4了
      

  3.   

    没有用过这种,ACCESS的用法AspNetPager1.RecordCount = (int)Socut.Data.ExecuteScalar("SELECT COUNT(*) FROM 
      

  4.   

    大概看了一下,既然id是标识列,值怎么可能是1\2\4?3哪去了?另外AspNetPager本身就是StartRecordIndex和EndRecordIndex属性,分别表示当前页记录的起始索引和结束索引,楼主无需自己去计算,直接把这两个属性的值传过去就行了。
      

  5.   

    你去AspNetPager官方网站找,有存储过程,如有需要修改你可以仿照修改就可以了,不用修改的话你都可以直接拿过来用,连例子都给你写好了。
      

  6.   

    你的做法,通常是不会生成你举的例子里那样的数据,
    想实现你要求的那样的话,只有该方法分页了.
    create proc pro_purinpt 
    @setypeid          int,//传进来一个参数 
    @startIndex        int, //起始页 
    @endIndex          int //位置页 
    as 
    begin 
    declare @indextable table(id int identity(1,1),nid int) 
    insert into @indextable(nid) select poid from tb_purvey order by poid desc  
    select top @endIndex-@startIndex * from (
    select top @endIndex  tb_inpt.*,tb_purvey.*,t.id as orderId //这里是你寻要的的字段
            from tb_inpt inner join tb_purvey //连接一个表 
             on tb_inpt.userid = tb_purvey.userid 
            inner join tb_third 
            on tb_purvey.pogenre = tb_third.thtypeid //连接二个表 
             inner join @indextable t on            
            tb_purvey.poid = t.nid 
            where tb_third.setypeid = @setypeid order by t.id 
         ) as tab1 order by tab1.orderId desc如果觉得查处来的结果是倒排序的有影响的话
    在select最外层再倒排序以下就可以了
      

  7.   


    ALTER PROCEDURE [dbo].[SetPage_Proc]
    /*
    ***************************************************************
    ** 分页存储过程 **
    ***************************************************************
    参数说明:
    1.Tables :表名称,视图
    2.PrimaryKey :主关键字
    3.Sort :排序语句,不带Order By 比如:NewsID Desc,OrderRows Asc
    4.CurrentPage :当前页码
    5.PageSize :分页尺寸
    6.Filter :过滤语句,不带Where 
    7.Group :Group语句,不带Group By
    效果演示:http://www.cn5135.com/_App/Enterprise/QueryResult.aspx
    ***************************************************************/
    (
    @Tables varchar(1000),
    @PrimaryKey varchar(100),
    @Sort varchar(200) = NULL,
    @CurrentPage int = 1,
    @PageSize int = 10,
    @Fields varchar(1000) = '*',
    @Filter varchar(1000) = NULL,
    @Group varchar(1000) = NULL
    )
    AS
    /*默认排序*/
    IF @Sort IS NULL or @Sort = ''
    SET @Sort = @PrimaryKey
    DECLARE @SortTable varchar(100)
    DECLARE @SortName varchar(100)
    DECLARE @strSortColumn varchar(200)
    DECLARE @operator char(2)
    DECLARE @type varchar(100)
    DECLARE @prec int
    /*设定排序语句.*/
    IF CHARINDEX('DESC',@Sort)>0
    BEGIN
    SET @strSortColumn = REPLACE(@Sort, 'DESC', '')
    SET @operator = '<='
    END
    ELSE
    BEGIN
    IF CHARINDEX('ASC', @Sort) = 0
    SET @strSortColumn = REPLACE(@Sort, 'ASC', '')
    SET @operator = '>='
    END
    IF CHARINDEX('.', @strSortColumn) > 0
    BEGIN
    SET @SortTable = SUBSTRING(@strSortColumn, 0, CHARINDEX('.',@strSortColumn))
    SET @SortName = SUBSTRING(@strSortColumn, CHARINDEX('.',@strSortColumn) + 1, LEN(@strSortColumn))
    END
    ELSE
    BEGIN
    SET @SortTable = @Tables
    SET @SortName = @strSortColumn
    END
    Select @type=t.name, @prec=c.prec
    FROM sysobjects o 
    JOIN syscolumns c on o.id=c.id
    JOIN systypes t on c.xusertype=t.xusertype
    Where o.name = @SortTable AND c.name = @SortName
    IF CHARINDEX('char', @type) > 0
    SET @type = @type + '(' + CAST(@prec AS varchar) + ')'
    DECLARE @strPageSize varchar(50)
    DECLARE @strStartRow varchar(50)
    DECLARE @strFilter varchar(1000)
    DECLARE @strSimpleFilter varchar(1000)
    DECLARE @strGroup varchar(1000)
    /*默认当前页*/
    IF @CurrentPage < 1
    SET @CurrentPage = 1
    /*设置分页参数.*/
    SET @strPageSize = CAST(@PageSize AS varchar(50))
    SET @strStartRow = CAST(((@CurrentPage - 1)*@PageSize + 1) AS varchar(50))
    /*筛选以及分组语句.*/IF @Filter IS NOT NULL AND @Filter != ''
    BEGIN
    SET @strFilter = ' Where ' + @Filter + ' '
    SET @strSimpleFilter = ' AND ' + @Filter + ' '
    END
    ELSE
    BEGIN
    SET @strSimpleFilter = ''
    SET @strFilter = ''
    END
    IF @Group IS NOT NULL AND @Group != ''
    SET @strGroup = ' GROUP BY ' + @Group + ' '
    ELSE
    SET @strGroup = ''
    /*执行查询语句*/
    EXEC(
    '
    DECLARE @SortColumn ' + @type + '
    SET ROWCOUNT ' + @strStartRow + '
    Select @SortColumn=' + @strSortColumn + ' FROM ' + @Tables + @strFilter + ' ' + @strGroup + ' orDER BY ' + @Sort + '
    SET ROWCOUNT ' + @strPageSize + '
    Select ' + @Fields + ' FROM ' + @Tables + ' Where ' + @strSortColumn + @operator + ' @SortColumn ' + @strSimpleFilter + ' ' + @strGroup + ' orDER BY ' + @Sort + '
    '
    )--得到此表的总的记录数 zhangl
    Declare @sqlcount varchar(500)
    set @sqlcount=N''
    set @sqlcount='select count(1) from '+@Tables+' '
    Exec (@sqlcount) 配合这个分页存储过程试试
      

  8.   

    59606208 群专注  NetAdvantage技术开发讨论 ,简单的问题 到群上一问就很快可以 得到解答了 希望能共同交流!