PagedDataSource pds = new PagedDataSource();//实例化分页类。每一次回发,都创建pds实例吗?

解决方案 »

  1.   

    你说的一系列症状说明PagedDataSource没有数据你应该先查询绑定再指定PageIndex,在你的bangding方法中。参考
    http://3941954.blog.51cto.com/3931954/791488
    的写法。
      

  2.   

    呵呵,例如 pds.CurrentPageIndex = pds.CurrentPageIndex-1 这句如果真的执行到这里,那么你永远都是得到 -1。而 pds.CurrentPageIndex = pds.CurrentPageIndex+1 永远都得到 1。因为你的 pds 都是刚刚重新初始化来的!如果要这么麻烦地去使用分页功能,那么你至少需要在ViewState上有 CurrentPageIndex 值,而不是 pds。
      

  3.   

    不懂啊,怎么在数据库层面分页?我应该学习些什么?
    跟你这个问题没有直接关系。他是说你的代码 string oo = "select * from Table_1 " 这里可以仅返回5条记录,而不是返回所有记录。这是sql语句问题,跟你的“翻页时的 pds.CurrentPageIndex 赋值语句值出错”没有直接关系。
      

  4.   

    不懂啊,怎么在数据库层面分页?我应该学习些什么?
    跟你这个问题没有直接关系。他是说你的代码 string oo = "select * from Table_1 " 这里可以仅返回5条记录,而不是返回所有记录。这是sql语句问题,跟你的“翻页时的 pds.CurrentPageIndex 赋值语句值出错”没有直接关系。
    奥,原来是这样。我根据您说的方法,我把PagedDataSource类定义成静态全局的,问题解决了。您太厉害了!!!万分万万分感谢。。
      

  5.   

    不懂啊,怎么在数据库层面分页?我应该学习些什么?
    跟你这个问题没有直接关系。他是说你的代码 string oo = "select * from Table_1 " 这里可以仅返回5条记录,而不是返回所有记录。这是sql语句问题,跟你的“翻页时的 pds.CurrentPageIndex 赋值语句值出错”没有直接关系。
    奥,原来是这样。我根据您说的方法,我把PagedDataSource类定义成静态全局的,问题解决了。您太厉害了!!!万分万万分感谢。。关系大了,PagedDataSource是从数据库加载数据后才分页的(十分浪费内存),你说正式的工作中有那几个用到了PagedDataSource,sp1234不是很喜欢噴用控件的人的么~,怎么这次不好好地说说这个小菜鸟~
    知道实体的概念+linq后,PagedDataSource根本就没有学习和使用的价值了你知道用静态使用的后果么~ 你现在模拟多用户浏览你做的这个页面,
    用户A,点击第二页后,用户B刷新页面看看~ 两个页面的数据应该相同~但用户B只是想刷新页面~
    就算两个用户页面不同 但PagedDataSource永远不会被释放~关于数据库层分页 搜索: sql分页~
      

  6.   

    不懂啊,怎么在数据库层面分页?我应该学习些什么?
    跟你这个问题没有直接关系。他是说你的代码 string oo = "select * from Table_1 " 这里可以仅返回5条记录,而不是返回所有记录。这是sql语句问题,跟你的“翻页时的 pds.CurrentPageIndex 赋值语句值出错”没有直接关系。
    奥,原来是这样。我根据您说的方法,我把PagedDataSource类定义成静态全局的,问题解决了。您太厉害了!!!万分万万分感谢。。关系大了,PagedDataSource是从数据库加载数据后才分页的(十分浪费内存),你说正式的工作中有那几个用到了PagedDataSource,sp1234不是很喜欢噴用控件的人的么~,怎么这次不好好地说说这个小菜鸟~
    知道实体的概念+linq后,PagedDataSource根本就没有学习和使用的价值了你知道用静态使用的后果么~ 你现在模拟多用户浏览你做的这个页面,
    用户A,点击第二页后,用户B刷新页面看看~ 两个页面的数据应该相同~但用户B只是想刷新页面~
    就算两个用户页面不同 但PagedDataSource永远不会被释放~关于数据库层分页 搜索: sql分页~
    我发现你们对程序在底层怎么跑非常清楚,比如你说在内存分页很浪费。我怎么不清楚这些,还有你说什么实体+linq什么的。哎,不知道的东西怎么这么多。要怎么才能达到既能实现效果又能知道底层的运行从而优化代码。看来,任重道远
      

  7.   

    如果连状态  pds.CurrentPageIndex 怎样保持一致都没有搞懂,又掉头搞什么“sql分页”,这岂不陷入那“成事不足败事有余”的怪圈里去了?!还是先把在使用pds组件进行分页下的这个程序搞懂,再去搞别的东西吧。我告诉你一个基本道理,真正的技术是“一小步一小步”去重构的,也就是说你的代码应该仅仅修改两三行代码先让它完全实现,然后才会因为性能问题(仅仅在将来确实有证据证明已经出现了性能问题)才重构。没有说一个事情不成,就推倒了去学另外一个事情的。邯郸学步的结果必定是在浅表的层面上行走,哪个都没有学会。
      

  8.   


    我没有跟你说过static。我告诉你的是,页面范畴的状态是要在ViewState中保持的。因此 pds.CurrentPageIndex 需要设计为当前页面实例范畴的。比如说public int CurrentPageIndex
    {
        get{ return (int)(ViewState["pIndex"]??0); }
        set{ ViewState["pIndex"]=value; }
    }
    你应该用这个 CurrentPageIndex 属性来记录当前的页号。在你的 private void bangding(int currentpage) 写一行
        CuttrentPageIndex = currentPage;
    而                pds.CurrentPageIndex = pds.CurrentPageIndex+1;
                    bangding(pds.CurrentPageIndex);
     这种语句应该改为                               bangding(CurrentPageIndex + 1);              
      

  9.   

    其实正好在你扯上“sql分页”时,你是不是更加需要懂得如何在回发(上一页、下一页)的时候取得 CurrentPageIndex 的知识呢?你看哪个嚷嚷着让你邯郸学步的“必须现在就sql分页”的说法,告诉你如何正确地取得 CurrentPageIndex 的值了吗?时髦的说法其实谁都会说。但是我们看到了“邯郸学步”根本无用,知道你必须先学会ViewState来处理你的ItemCommand事件中的回发求CurrentPageIndex值得问题,才会告诉你那个说法“跟你这个问题没有直接关系”的。这里谈的才是有关系、必须先知道的知识。只有知道如何计算 CurrentPageIndex,你才可能不被别的什么时髦说法所害。
      

  10.   

    要想成功 努力是必不可少的
    但要加快成功的时间 就要向成功的人学习 来减少弯路那么请问sp1234 那些php jsp js.node ruby....等程序员在没有PagedDataSource可以使用的情况下
    他们是怎么实现分页的呢~ 还不是直接数据库分页~
    当年微软就不应该搞个PagedDataSource这个丑陋的东西出来
    现在有泛型的情况下,你还会去学集合么~
      

  11.   

    ViewState是楼主当前解决问题的钥匙,但楼主开发思路还是有很大的问题。
      

  12.   


    我没有跟你说过static。我告诉你的是,页面范畴的状态是要在ViewState中保持的。因此 pds.CurrentPageIndex 需要设计为当前页面实例范畴的。比如说public int CurrentPageIndex
    {
        get{ return (int)(ViewState["pIndex"]??0); }
        set{ ViewState["pIndex"]=value; }
    }
    你应该用这个 CurrentPageIndex 属性来记录当前的页号。在你的 private void bangding(int currentpage) 写一行
        CuttrentPageIndex = currentPage;
    而                pds.CurrentPageIndex = pds.CurrentPageIndex+1;
                    bangding(pds.CurrentPageIndex);
     这种语句应该改为                               bangding(CurrentPageIndex + 1);              
    虽然还是不太懂您说的这些,不过我想,我现在遇到的一个问题应该就是您说的这个回传值的问题。我在前台加了一个Label,为了获取每次点击分页按钮时pds.CurrenPageInex的值,但是情况很糟糕,显示的值很错乱,一会儿为“1”,一会儿就是别的数字了。