对于VS2003DataGrid建立的一些困难与解决办法

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

10年积累的做网站、成都网站制作经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站设计后付款的网站建设流程,更有绥德免费网站建设让你可以放心的选择与我们合作。

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

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

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

 
 
  1.  
  2.  
  3.  
  4.  
  5. <%# DataBinder.Eval(Container, "DataItem.CityID")%> td> 
  6. <%# DataBinder.Eval(Container, "DataItem.ProvinceID")%> 
  7. td> 
  8. <%# DataBinder.Eval(Container, "DataItem.City")%> 
  9. td> 
  10. <%# 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) %>的方法。不过其可读性不高。

本文标题:对于VS2003DataGrid建立的一些困难与解决办法
文章起源:http://www.csdahua.cn/qtweb/news27/555277.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网