提高DB2 Web应用程序性能的五条规则

王朝c#·作者佚名  2006-12-17
窄屏简体版  字體:   |    |    |  超大  

优秀的代码行行相似,糟糕的代码各个不同。

规则其实并不重要,重要的是养成良好习惯。

——译者题记

提高DB2 Web应用程序性能的5条规则

作者:Glenn Stephens

2003年8月

内容

简介

规则1:按需检索

规则2:优化数据库

规则3:使用DB2 UDB的OLAP函数改善分页

规则4:使用存储过程

规则5:尽可能使用缓存

总结

简介

速度和可升级性是网络开发重要的性能要求,而且它们也不难达到。应用一些简单的规则会提高网络应用的性能。在本文中,您将了解到使用Borland® C#Builder和IBM® DB2®通用数据库(UDB)8.1开发快速Microsoft® ASP.NET Web应用程序的5条规则。

分析Web应用程序的性能需要利用一些手段来检测每个操作的性能。为此,我创建了一个TimeDiff类(见程序清单1),它可以计算数据库操作的用时。你可以利用TimeDiff类的检测结果作为衡量数据库操作性能的基准,来观察哪些操作最为有效。我还创建了一个配合TimeDiff 类使用的LOTSOFRECORDS表(见程序清单2),它包含10,000条记录,你可以通过对它的操作来观察不同技术之间的性能差异。DB2具有内部缓冲池,一旦运行一个查询,内部缓冲池启用,因此二次查询的速度较快。在检测查询速度时,请忽略缓冲池启用前的结果而采用启用后的结果。

程序清单1. TimeDiff类

/// 这个类用于时间计算。在例子中, /// 我们将利用它检测数据库操作的速度, /// 以便作性能上的比较。 /// public class TimeDiff { DateTime StartTime; DateTime EndTime; public TimeDiff() {} public void Start() { StartTime = DateTime.Now; } public void Stop() { EndTime = DateTime.Now; } public string TimeDifferenceText { get { TimeSpan TimeDifference = EndTime - StartTime; return TimeDifference.ToString(); } } }}

System.Web.UI.WebControls.DataGridPageChangedEventArgs e){ //Change the active page of the data dataGrid1.CurrentPageIndex = e.NewPageIndex; BindToTheData();}

System.Web.UI.WebControls.DataGridPageChangedEventArgs e){ LoadSingleDataPage(e.NewPageIndex);}

(2)生成存储过程执行计划;

(3)数据返回应用程序。

然后进行如下查询:

PRODUCTLIST.UNITPRICE, PRODUCTLIST.IMAGEURL FROM GLENN.PRODUCTLIST AS PRODUCTLIST WHERE PRODUCTLIST.CATEGORYCODE = 2;

图2 利用DB2开发中心的存储过程向导创建一个新的存储过程

图3 创建存储过程输入参数

PRODUCTLIST.UNITPRICE, PRODUCTLIST.IMAGEURL FROM GLENN.PRODUCTLIST AS PRODUCTLIST WHERE PRODUCTLIST.CATEGORYCODE = CATCODE; -- Cursor left open for client application OPEN cursor1;END P1

 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
© 2005- 王朝網路 版權所有 導航