《net网站优化》word版

《net网站优化》word版

ID:30365326

大小:101.84 KB

页数:22页

时间:2018-12-29

《net网站优化》word版_第1页
《net网站优化》word版_第2页
《net网站优化》word版_第3页
《net网站优化》word版_第4页
《net网站优化》word版_第5页
资源描述:

《《net网站优化》word版》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、net网站优化一、数据库操作1、用完马上关闭数据库连接访问数据库资源需要创建连接、打开连接和关闭连接几个操作。这些过程需要多次与数据库交换信息以通过身份验证,比较耗费服务器资源。ASP.NET中提供了连接池(ConnectionPool)改善打开和关闭数据库对性能的影响。系统将用户的数据库连接放在连接池中,需要时取出,关闭时收回连接,等待下一次的连接请求。连接池的大小是有限的,如果在连接池达到最大限度后仍要求创建连接,必然大大影响性能。因此,在建立数据库连接后只有在真正需要操作时才打开连接,使用完毕后马上关闭,从而尽量减少数据库连接打开的时间,避

2、免出现超出连接限制的情况。用(推荐)using(SqlConnectionConn=newSqlConnection(connstr)){}//不必显示关闭或try{conn.Open();}catch{}finally{conn.Close();}2、尽量使用存储过程,并优化查询语句存储过程是存储在服务器上的一组预编译的SQL语句,类似于DOS系统中的批处理文件。存储过程具有对数据库立即访问的功能,信息处理极为迅速。使用存储过程可以避免对命令的多次编译,在执行一次后其执行规划就驻留在高速缓存中,以后需要时只需直接调用缓存中的二进制代码即可。在.

3、NETFramework提供的所有数据访问方法中,基于SQLServer的数据访问是生成高性能、可缩放Web应用程序的推荐选择。使用托管SQLServer提供程序时,可通过使用编译的存储过程而不是特殊查询获得额外的性能提高。另外,存储过程在服务器端运行,独立于ASP.NET程序,便于修改,最重要的是它可以减少数据库操作语句在网络中的传输。优化查询语句ASP.NET中ADO连接消耗的资源相当大,SQL语句运行的时间越长,占用系统资源的时间也越长。因此,尽量使用优化过的SQL语句以减少执行时间。比如,不在查询语句中包含子查询语句,尽量只返回有用的数据

4、、字段,充分利用索引等。3、只读数据访问用SqlDataReader,不要使用DataSetSqlDataReader类提供了一种读取从SQLServer数据库检索的只进数据流的方法。如果当创建ASP.NET应用程序时出现允许您使用它的情况,则SqlDataReader类提供比DataSet类更高的性能。情况之所以这样,是因为SqlDataReader使用SQLServer的本机网络数据传输格式从数据库连接直接读取数据。另外,SqlDataReader类实现IEnumerable接口,该接口也允许您将数据绑定到服务器控件。DataSet作为一个功

5、能强大的、支持离线的数据库,其对性能的开销也相对较大。Sqldataread优点:读取数据非常快。如果对返回的数据不需做大量处理的情况下,建议使用SqlDataReader,其性能要比datset好很多。缺点:直到数据读完才可close掉于数据库的连接。Dataset是把数据读出,缓存在内存中。缺点:对内存的占用较高。如果对返回的数据需做大量的处理用Dataset比较好些可以减少对数据库的连接操作。优点:只需连接一次就可close于数据库的连接。一般情况下,读取大量数据,对返回数据不做大量处理用SqlDataReader.对返回数据大量处理用da

6、tset比较合适.对SqlDataReader和Dataset的选择取决于程序功能的实现。4、数据的绑定DataBinder一般的绑定方法%#DataBinder.Eval(Container.DataItem,"字段名")%用DataBinder.eval绑定不必关心数据来源(read或dataset)。不必关心数据的类型eval会把这个数据对象转换为一个字符串。在底层绑定做了很多工作,使用了反射性能。正因为使用方便了,但却影响了数据性能。来看下%#DataBinder.Eval(Container.DataItem,"字段名")%。当于dat

7、aset绑定时,DataItem其实式一个DataRowView(如果绑定的是一个数据读取器(dataread)它就是一个IdataRecord。)因此直接转换成DataRowView的话,将会给性能带来很大提升。%#ctype(Container.DataItem,DataRowView).Row("字段名")%对数据的绑定建议使用%#ctype(Container.DataItem,DataRowView).Row("字段名")%。使用时注意两个方面:1.需在页面添加%@Importnamespace="System.Data"%.2.注意字

8、段名的大小写(要特别注意)。如果和查询的不一致,在某些情况下会导致比%#DataBinder.Eval(Container.DataIt

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。