对于VS 2003DataGrid建立的一些困难与解决办法

开发 后端
我的观点:Repeater 要比VS 2003DataGrid的效率好,不测试不知道,一测试可真要命啊!我用的VS2003自带的那个压力测试软件测试了一下二者的性能,用每秒可以支持的访问人数来作为衡量标准。

本章讲的是VS 2003DataGrid的介绍与技巧,怎样创建VS 2003DataGrid。这些内容都是我花了几个月的时间查阅资料并向IT精英们学习出来的,中间可能有不少错误是我没有挑出的,欢迎大家指正。

但是结果却出乎我的意料,DataGrid 的效率 要比 Repeater高!详细说一下我的测试方法,请大家看看我的测试方法有没有什么问题,如果没有什么问题的话,那么发生这种想象的原因是什么呢?

硬件:cpu:AMD XP2000+ 、80G硬盘、512M内存。软件:windows 2003 + sp1 、VS2003 、SQL Server 2000 + sp4测试数据:显示一张表(城市表)里的数据,4个字段,349条记录。测试目的:网站的页面里面显示数据的效率。只测试显示数据的功能,不管其他的方面

VS 2003DataGrid 使用自动填充,repeater的代码:

  1. <table id="DG" > 
  2. <asp:repeater id="Rpt_Test" runat="server"> 
  3. <ItemTemplate> 
  4. <tr> 
  5. <td><%# DataBinder.Eval(Container, "DataItem.CityID")%>td> 
  6. <td><%# DataBinder.Eval(Container, "DataItem.ProvinceID")%> 
  7. td> 
  8. <td><%# DataBinder.Eval(Container, "DataItem.City")%> 
  9. td> 
  10. <td><%# DataBinder.Eval(Container, "DataItem.AeraCode")%> 
  11. td> 
  12. tr> 
  13. ItemTemplate> 
  14. asp:repeater>table> 

常看到一些文章说 repeater 比 VS 2003DataGrid 的性能要好,但是,我的测试结果是怎么回事呢?

测试结果:

显示 10条记录 ,没有 ViewState ,DataTable 绑定控件,DataGrid使用绑定列。

1、 DataGrid : 250 rps 左右。

2、 Repeater : <%# DataBinder.Eval(Container, "DataItem.CityID")%>方法: 200 rps 左右。

3、Repeater : <%# ((DataRowView)Container.DataItem)["CityID"] %>方法 : 250 rps 多一点点。

4、Repeater : <%# ((DataRowView)Container.DataItem)[0] %>方法 : 250 rps 多一点点。

其中 3、4 是我刚找到的一种绑定数据的方法。看来是 <%# DataBinder.Eval(Container, "DataItem.CityID")%>这种绑定方法效率太低了。

一般的绑定方法<%# DataBinder.Eval(Container.DataItem, "字段名") %>用DataBinder.eval 绑定不必关心数据来源(Dataread或dataset)。不必关心数据的类型eval会把这个数据对象转换为一个字符串。在底层绑定做了很多工作,使用了反射性能。#t#

正因为使用方便了,但却影响了数据性能。来看下<%# DataBinder.Eval(Container.DataItem, "字段名") %>。当于dataset绑定时,DataItem其实式一个DataRowView(如果绑定的是一个数据读取器(dataread)它就是一个 IdataRecord。)因此直接转换成DataRowView的话,将会给性能带来很大提升。

对数据的绑定建议使用<%# ctype(Container.DataItem,DataRowView).Row("字段名") %>。数据量大的时候可提高几百倍的速度。使用时注意2方面:1.需在页面添加<%@ Import namespace="System.Data"%>.2.注意字段名的大小写(要特别注意)。如果和查询的不一致,在某些情况下会导致比< %# DataBinder.Eval(Container.DataItem, "字段名") %>还要慢。如果想进一步提高速度,可采用<%# ctype(Container.DataItem,DataRowView).Row(0) %>的方法。不过其可读性不高。

责任编辑:chenqingxiang 来源: NET130
相关推荐

2009-11-30 13:51:28

VS2003 Acti

2009-12-01 09:06:36

VS2003 ajax

2009-12-01 16:16:13

安装VS2003

2009-11-26 13:40:53

2009-12-01 10:18:12

VS2003makef

2009-11-27 09:34:38

VS2003命令

2009-11-30 13:51:28

VS2003 Runt

2009-12-01 14:44:46

VS2005 PRO

2009-11-30 13:40:43

VS 2003 Boo

2009-11-30 13:51:28

VS2005 菜单

2009-11-30 10:41:36

VS2003无法启动调

2009-06-25 09:50:32

JSF

2009-11-30 09:39:46

VS2003版本

2009-11-27 13:04:16

VS2005远程调试

2009-11-26 16:46:08

VS2003编译

2009-12-02 16:02:58

VS2010编辑器

2009-11-30 17:28:39

VS2003 ASP

2009-11-30 11:05:19

VS2003 WebS

2009-11-25 13:35:05

VS2003使用

2009-11-25 16:35:25

VS 2003系统
点赞
收藏

51CTO技术栈公众号