设为首页 友情链接
在线留言 发表文章
加入收藏 广告联系

刺猬首页

| 专案技术 | 网络技术 | 图形图象 | 网络编程 | 网页设计 | 操作系统 | 服务器 | 技术白皮书 | 在线实验室 | 刺猬论坛 |
小说专版  | 数据库 | 设计赏析 | 存储频道 | 网络安全 | 私服架设 |  Solaris | 网站评估 | PC维护技巧 | 下载中心 | 博 客 |
专   题: | Linux | java | cisco | 防病毒 | 刀片 | SOA | iscsi | ASP.NET | SQL | Oracle |
您现在的位置: IT公社 IT community >> 数据库应用 >> MY SQL >> 教程正文 用户登录 新用户注册
专 题 栏 目
最 新 热 门
最 新 推 荐
相 关 文 章
基于DB2的数据库应用系统…
DB2数据库中提高INSERT性…
DB2数据库中提高INSERT性…
SQL Server 2005与DB2 8…
国内学院派专家对DB2 9新…
教你如何构建DB2 Cube V…
DB2数据库创建存储过程时…
访问大型机、小型机上DB…
DB2 9安装方法简介
安装DB2 9需要的内存和磁…
  提高DB2 Web应用程序性能的五条规则           
提高DB2 Web应用程序性能的五条规则
 

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

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

                         ——译者题记

简介

速度和可升级性是网络开发重要的性能要求,而且它们也不难达到。应用一些简单的规则会提高网络应用的性能。在本文中,您将了解到使用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类

using System;
namespace Effeciency
{
/// 
/// 这个类用于时间计算。在例子中,
/// 我们将利用它检测数据库操作的速度,
/// 以便作性能上的比较。 
/// 
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();
}
}
}
}

程序清单2. LOTSOFRECORDS的表定义

CREATE TABLE "GLENN "."LOTSOFRECORDS" (
"KEYCOL" INTEGER NOT NULL , 
"COL1" CHAR(50) , 
"COL2" CHAR(50) , 
"COL3" CHAR(50) , 
"COL4" CHAR(50) , 
"COL5" CHAR(50) , 
"COL6" CHAR(50) , 
"COL7" CHAR(50) , 
"COL8" CHAR(50) , 
"COL9" CHAR(50) , 
"COL10" CHAR(50) ) 
IN "USERSPACE1" ; 
COMMENT ON TABLE "GLENN "."LOTSOFRECORDS" IS 'Table designed to Contain Lots of Records';

-- DDL Statements for primary key on Table "GLENN "."LOTSOFRECORDS"

ALTER TABLE "GLENN "."LOTSOFRECORDS" 
ADD CONSTRAINT "CC1058255334652" PRIMARY KEY
("KEYCOL");

下面,我们就开始介绍这些提高DB2 UDB Web 应用程序性能的规则。我会先介绍提高数据库性能的基本规则,然后列出一些适合以Borland Data Provider开发ASP.NET应用时的性能规则。

规则1:按需检索

如果你只能记得住一条规则,那一定要记住这一条:按需检索。如果你是“幸存者”电视节目的忠实观众,您会记得其中的参赛者通过限额分配来保证每个人都有充足的食物。这种做法对于数据库开发同样适用。如果你的应用程序能够按需运行,那么就会合理地将数据库和网络资源留给其他应用。这听起来很简单,但我们还是来看一个例子

假设有一个包含10,000 行记录和10 个字段的表,以及一个需要显示所有记录但只显示3个字段的Web页。很多开发者经常图省事而使用"select *"语句选择所有的字段:

select * from GLENN.LOTSOFRECORDS

这种做法应当避免,而应力求只检索需要的字段。可以在SQL 语句中定义要检索的字段,例如:
<CENTER><ccid_nobr>
<table width="400" border="1" cellspacing="0" cellpadding="2" bordercolorlight = "black" bordercolordark = "#FFFFFF" align="center">
<tr>
    <td bgcolor="e6e6e6" class="code" style="font-size:9pt">
    <pre><ccid_code> 
select 
KEYCOL, COL1, COL2, COL7 
from 
GLENN.LOTSOFRECORDS

在本文附带的源程序中,有两个ASP.NET页面:一个是RetrievingAllFields.aspx,它执行第一个查询;另一个是RetrievingLimitedFields.aspx ,它执行第二个查询,即只检索需要的字段。

用TimeDiff类进行检测,执行第一个查询用了1.622 秒,执行第二个查询用了1.311秒。后者用时只是前者的80%,不仅用时少,而且还减少了Web应用程序和数据库服务器之间的网络数据堵塞。

这个例子只限制了检索的字段,你还可以使用WHERE语句限制检索的记录数。WHERE 语句可以限制服务器返回的记录数(见程序清单3)。要记住,通过网络发送的记录数据越少,对应用程序、数据库、用户和网络越有好处。

规则2:优化数据库

有时候你的Web应用程序可能运行得不错,但你想让它更好。一个简单的减少搜索时间的方法是为特定字段创建索引。如果有一个查询是要搜索某个价格范围内的产品(见程序清单3),但你没有为价格字段定义索引,那么返回数据就会多花一些时间。而一旦建立了索引,DB2会很快返回你想要的结果。

程序清单3. 利用索引进行数据库搜索

SELECT 
PRODUCTCODE, PRODUCTNAME, DESCRIPTION, UNITPRICE
FROM 
GLENN.PRODUCTLIST 
WHERE 
UNITPRICE > 20.00

优化数据库不只是为搜索字段创建索引这么一条,你应当尽可能多地搜集相关的DB2信息以使应用程序运行得更好。经常访问IBM发者园地(IBM DB2 Developer Domain)和comp.databases.ibm-db2(comp.databases.ibm-db2)等一些相关的Web站点或新闻组,对于保持DB2开发技巧不断更新是一个很好的办法。

你还应当努力熟悉DB2附带的工具,例如DB2索引建议器(Index Advisor)。DB2索引建议器可以根据你递交的查询和所连接的数据库返回最佳索引列表。

规则3:使用DB2 UDB的OLAP功能改善分页

在ASP.NET中,一个最常见的操作是表格分页显示。ASP.NET中DataGrid组件的默认设置是将表格需要的所有记录都返回客户端,然后再根据选择的页显示相应记录.

程序清单4 使用DataGrid 内建分页机制

TimeDiff diff = new TimeDiff();
private DataSet GetProductsDataSet() {
diff.Start();
string connString = ConfigurationSettings.AppSettings["database"];
BdpConnection conn = new BdpConnection(connString);
BdpDataAdapter da = new BdpDataAdapter("select KEYCOL, " +
"COL1, COL2, COL7 FROM GLENN.LOTSOFRECORDS "+
"ORDER BY KEYCOL ASC", conn);
DataSet ds = new DataSet();
da.Fill(ds, "Table1");
diff.Stop();
return ds;
}

private void BindToTheData()
{
dataGrid1.DataSource = GetProductsDataSet();
dataGrid1.DataMember = "Table1";
dataGrid1.DataBind();
label1.Text = diff.TimeDifferenceText;
}

private void Page_Load(object sender, System.EventArgs e)
{
if (!IsPostBack) {
BindToTheData();
}
}

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

如果以LOTSOFRECORDS表为例,从数据库中检索1万条记录很快就会占尽网络带宽,尤其是一次只需要查看10条或20条记录时。用户会发现加载ASP.NET页面的时间太长,而且很可能会超时。试想,如果数据库有数百万条记录,那你的应用程序就会运行缓慢只至停止执行。因此,需要采取更好的方法来检索数据。

还好,DataGrid组件允许定制分页。你可以计算哪些记录需要显示,然后只从服务器检索出相应的记录。

后来版本的DB2 UDB都具有一个很大的特点,那就是OLAP函数,它允许你进行各种记录检索。例如,只检索某些记录可以执行如下的查询:

SELECT * FROM 
(SELECT KEYCOL, COL1, COL2, COL7, rownumber() 
over(ORDER BY KEYCOL ASC) AS rn 
FROM GLENN.LOTSOFRECORDS 
ORDER BY KEYCOL ASC) AS a1 
WHERE a1.rn BETWEEN 100 AND 120

使用DataGrid定制分页时,需要获得特定页的DataSet。GetDataByPage方法可以检索结果集而不管分页数和分页大小:

private DataSet GetDataByPage(int PageNo, int PageSize, out int NumberOfPages)
{
int startRecord = (PageNo - 1) * PageSize + 1;
int endRecord = startRecord + PageSize - 1;

string connString = ConfigurationSettings.AppSettings["database"];
BdpConnection conn = new BdpConnection(connString);
conn.Open();

//Get the number of Pages
string sRecordCount = "select count(*) from GLENN.LOTSOFRECORDS";
BdpCommand cmdGetRecordCount = new BdpCommand(sRecordCount, conn);
int intRecordCount = (int)cmdGetRecordCount.ExecuteScalar();
NumberOfPages = intRecordCount / PageSize;
if (intRecordCount % PageSize > 0)
NumberOfPages++;

//Get the data specifically for the page
string sSQL =
"SELECT * FROM " +
" (SELECT KEYCOL, COL1, COL2, COL7, rownumber() " +
" over(ORDER BY KEYCOL ASC) AS rn " +
" FROM GLENN.LOTSOFRECORDS " +
" ORDER BY KEYCOL ASC) AS a1 " +
" WHERE a1.rn BETWEEN ? AND ?";
BdpCommand cmdSel = new BdpCommand(sSQL, conn);
BdpParameter prmStart =
cmdSel.Parameters.Add("StartRecord", BdpType.Int32);
prmStart.Value = startRecord;
BdpParameter prmEnd =
cmdSel.Parameters.Add("EndRecord", BdpType.Int32);
prmEnd.Value = endRecord;
BdpDataAdapter da = new BdpDataAdapter(cmdSel, conn);
DataSet ds = newDataSet();
da.Fill(ds, "Table1");

diff.Stop();
return ds;
}

private void LoadSingleDataPage(int pageNo)
{
//Display the Page contents
int PageCount;
DataSet dsData = GetDataByPage(pageNo+1,
dataGrid1.PageSize, out PageCount);
dataGrid1.VirtualItemCount = PageCount * dataGrid1.PageSize;
dataGrid1.CurrentPageIndex = pageNo;
dataGrid1.DataSource = dsData;
dataGrid1.DataBind();
}

private void Page_Load(object sender, System.EventArgs e)
{
if (!IsPostBack)
{
LoadSingleDataPage(0);
}
}

private void dataGrid1_PageIndexChanged(object source, System.Web.UI.WebControls.DataGridPageChangedEventArgs e)
{
LoadSingleDataPage(e.NewPageIndex);
}

通过定制分页,将检索记录数从1万条限制到20条,占用的网络资源约为最初的0.2%。在我的本机用TimeDiff 类检测,使用定制分页时用时0.5~0.7秒,而使用默认分页机制时用时为0.9~1.5秒。

规则4:使用存储过程

如果发送一条SQL语句到DB2服务器,其执行过程如下:

(1)DB2 UDB Server对SQL语句进行语法检查;

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

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

当使用存储过程时,前两步过程已经完成。存储过程经编译后,调用时只将存储过程名和参数传递给数据库服务器。因此,执行时间的减少赢得了性能上的优势。但这种优势只有当返回的结果集非常大时才有所体现。

下面举一个例子。先建立一个PRODUCTLIST表:

CREATE TABLE "GLENN "."PRODUCTLIST" (
"PRODUCTCODE" VARCHAR(20) NOT NULL , 
"PRODUCTNAME" VARCHAR(50) NOT NULL , 
"DESCRIPTION" VARCHAR(255) , 
"UNITPRICE" DOUBLE NOT NULL , 
"CATEGORYCODE" INTEGER , 
"IMAGEURL" CHAR(150) ) 
IN "USERSPACE1" ; 
COMMENT ON TABLE "GLENN "."PRODUCTLIST" IS 'A list of Products in the Shopping Cart';

-- DDL Statements for primary key on Table &

[1] [2] 下一页

频道声明:本频道的文章除部分特别声明禁止转载的专稿外,可以自由转载.但请务必注明出出处和原始作者 文章版权归本频道与文章作者所有.对于被频道转载文章的个人和网站,我们表示深深的谢意。

原始作者:佚名 录入时间:2007-1-2 5:46:26
信息来源:不详 投稿信箱:itqoo@126.com
教程录入:itqoo    责任编辑:itqoo 
  • 上一个教程:

  • 下一个教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    - 关于我们 - 合作伙伴 - 友情链接 - 广告刊登 - 投稿热线 - 在线留言版权声明联系方式 -
    IT公社版权所有 粤ICP备05127012号
    Copyrigh@2005-2006 itqoo.com.Inc All Rights Reserved  推荐分辨率 1024*768
    联系站长:E-Mail:itqoo@126.com     MSN:urchincc@hotmail.com    QQ:点击这里给我发消息
    特别感谢:亿太网络提供空间支持