新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 本版讨论.NET,C#,ASP,VB技术
    [返回] 中文XML论坛 - 专业的XML技术讨论区计算机技术与应用『 Dot NET,C#,ASP,VB 』 → 大数量的分页方法,使用DataGrid分页总结 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 9396 个阅读者  浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: 大数量的分页方法,使用DataGrid分页总结 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     admin 帅哥哟,离线,有人找我吗?
      
      
      
      威望:9
      头衔:W3China站长
      等级:计算机硕士学位(管理员)
      文章:5255
      积分:18407
      门派:W3CHINA.ORG
      注册:2003/10/5

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给admin发送一个短消息 把admin加入好友 查看admin的个人资料 搜索admin在『 Dot NET,C#,ASP,VB 』的所有贴子 点击这里发送电邮给admin  访问admin的主页 引用回复这个贴子 回复这个贴子 查看admin的博客楼主
    发贴心情 大数量的分页方法,使用DataGrid分页总结


    发信人: little99 (拭目以待), 信区: DotNET        
    标  题: 大数量的分页方法,使用DataGrid分页总结
    发信站: BBS 水木清华站 (Mon Jul 22 09:12:35 2002)

    第一种:最笨的方法,设置DataGrid的AllowPaging属性为true,设置PageSize属性,
    然后编写OnPageIndexChange方法,设置所在页,重新获取DataSource的全部数据。
    这种方法在大数据量时延迟很大,也不易于服务器程序的扩展,不过特点就是代码
    量小,适合小数据不想做特殊处理的应用。

    第二种:设置DataGrid的AllowPaging和AllowCustomPaging的属性为true,允许自定义
    分页,设置PageSize,同时动态设置VirtualItemCount,来让DataGrid自动产生底部的
    分页导航栏。也要自己处理OnPageIndexChange方法,不过这里涉及到的方法很多,大概
    归结如下:
      1.读取DataSource的全部数据,自己处理Cache,每次根据请求的页号给DataGrid特定
        的数据。在数据量超大的时候,也没有想到很好的方法,可以缓存大量数据,而且对
        于更新频繁的数据,这种缓存的方法,还要考虑一致性的问题。
      2.采用数据库相关的方法,每次获取最多pagenumber*PageSize条记录,然后根据页号
        获取PageSize条或者最后的不足PageSize条记录。sql server采取top关键字,oracle
        则采用rownum或者rowid自动生成列。这个也缺乏扩展性,在数据量超大的时候效率
        低下。如共400万条记录,获取从第200万开始的连续10条记录,仍然很慢。
      3.采取数据库相关的方法,每次获取恰好的PageSize条记录,赋给DataGrid,这个根据
        不同的数据库,存在不同的方法。我只介绍oracle和sql server的方法:
        a. oracle的方法:
           select * from (select rownum as row_id, xxx, yyy from (select xxx, yyy
           from any_table [where ...][group by ...][order by ...])) where row_id
           between ((pagenumber-1)*PageSize+1) and pagenumber*PageSize
       b. sql server 7.0以上的方法
          b.1  使用存储过程:
    CREATE  PROCEDURE sp_FetchRecordByPage
    (@selectCmd varchar(128), @PageNumber smallint, @PageSize smallint)
    AS
    -- @selectCmd, use to create cursor

    -- @PageNumber, page to fetch
    -- @PageSize, records that fit into one page

    -- internal variables
      DECLARE @MyIndex smallint
      DECLARE @FirstRecPos smallint

    -- sets the position of the first record to
    -- retrieve in the page
      SET @FirstRecPos = (@PageNumber-1) * @PageSize + 1

    -- cursor associated with the query string
      EXEC('DECLARE select_cursor SCROLL CURSOR FOR ' + @selectCmd)
    -- opens the cursor
      OPEN select_cursor

    -- fetches the first record in the page
      FETCH ABSOLUTE @FirstRecPos FROM select_cursor

    -- loops through the cursor to pick up the
    -- other records in the page
      SET @MyIndex = 1
      WHILE @@FETCH_STATUS = 0 AND @MyIndex < @PageSize
      BEGIN
         FETCH NEXT FROM select_cursor
         SET @MyIndex = @MyIndex + 1
      END

    -- clean up
      CLOSE select_cursor
      DEALLOCATE select_cursor
    GO

        b.2使用sql语句,sql server 7.0以上支持top关键字
    SELECT * FROM
      (SELECT TOP pagenumber*PageSize * FROM anytable
      [where ...][group by ...][order by ...]) AS t1
       WHERE NOT EXISTS
      (SELECT * FROM (SELECT TOP (pagenumber-1)*Pagesize *
      FROM anytable [where ...][group by ...][order by ...])
       AS t2 WHERE t1.xxx=t2.xxx)
       xxx是表的主键,适合有主键的任何表

      问题如下:大数据量时哪种方法效率最高?个人感觉是采用存储过程,内部使用光标
      的方法,这个对于oracle也可以采用,不过不一定比oracle的select效率高,而且光标
      方法返回的是多个记录集,每个记录集一条记录,需要用DataReader读取后组装成
      DataTable或者DataSet然后作为数据源赋给DataGrid,不过也可以直接把DataReader
      赋给DataGrid,记得及时关闭数据链接就可以了
    --
    ****************
    I Love Seagull!
    ****************


    ※ 来源:·BBS 水木清华站 smth.edu.cn·[FROM: 166.111.68.100]
    上一篇
    返回上一页
    回到目录
    回到页首
    下一篇


       收藏   分享  
    顶(0)
      





    关闭广告显示

    ----------------------------------------------

    -----------------------------------------------

    第十二章第一节《用ROR创建面向资源的服务》
    第十二章第二节《用Restlet创建面向资源的服务》
    第三章《REST式服务有什么不同》
    InfoQ SOA首席编辑胡键评《RESTful Web Services中文版》
    [InfoQ文章]解答有关REST的十点疑惑

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2004/11/9 2:26:00
     
     xmzhy 帅哥哟,离线,有人找我吗?狮子座1978-8-18
      
      
      威望:5
      等级:计算机学士学位
      文章:385
      积分:2003
      门派:XML.ORG.CN
      注册:2003/10/22

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给xmzhy发送一个短消息 把xmzhy加入好友 查看xmzhy的个人资料 搜索xmzhy在『 Dot NET,C#,ASP,VB 』的所有贴子 引用回复这个贴子 回复这个贴子 查看xmzhy的博客2
    发贴心情 
    正好用上,谢谢!
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2004/12/27 17:10:00
     
     GoogleAdSense狮子座1978-8-18
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 Dot NET,C#,ASP,VB 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2025/7/17 8:57:13

    本主题贴数2,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    232.422ms