111111
精灵王
精灵王
  • 注册日期2010-12-08
  • 发帖数640
  • QQ
  • 火币1103枚
  • 粉丝120
  • 关注75
  • 社区明星
阅读:4529回复:0

datatable操作中的性能问题_asp.net技巧

楼主#
更多 发布于:2010-12-15 21:08
     最近的一项工作是关于性能提升方面的。要做的第一个事情是要把非常多同类型的DataTable合并到一起,查了非常多关于DataTable的相关函数以后,我决定用Merge函数来合并这些DataTable。
      DataTable[] srcTables = ... ;
      foreach( DataTable src in srcTables )
      {
         dest.Merge( src ) ;
      }
      不过测试的结果让我非常是失望,性能不是一般的不好。经过调查发现性能的瓶颈在Merge函数这里。后来经过测试,发现如果用下面的代码:
      DataTable[] srcTables = ... ;
      foreach( DataTable src in srcTables )
      {
         foreach( DataRow row in src.Rows)
         {
            dest.ImportRow( row ) ;      
         }
      }
  
      结果让人惊奇的是,下面的代面的速度是上面的代码速度的100倍!


     还做了一个事情,就是对DataTable进行filter的时候 ,我的一个同事和我说了以下的代码:
      DataView dv = dt.DefaultView ;
      dv.RowFilter = filter ;
      DataTable result = dv.ToTable() ;
      上面的代码是能工作的,不过他的性能一点都不好,后来我把上面的代码改成了:
      DataRow[] rows = dv.Select( filter ) ;
      foreach( DataRow row in rows )
      {
         result.ImportRow(row) ;
      }

     也有数十倍的性能提高。

喜欢0 评分0
游客

返回顶部