国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > Access > 正文

數(shù)據(jù)庫應(yīng)用程序需注意的問題

2024-09-07 19:03:38
字體:
供稿:網(wǎng)友

總的來說,提高應(yīng)用程序性能的最好的方法是發(fā)現(xiàn)應(yīng)用的瓶徑之所在,和數(shù)據(jù)庫進(jìn)行交互的性能無疑是決定應(yīng)用程序性能的重要環(huán)節(jié)之一。因為ADO是當(dāng)前最新的基于組件的數(shù)據(jù)庫編程的接口,這里我們主要討論用ADO編程所需要注意的問題,因為ADO是一個和編程語言無關(guān)的COM組件系統(tǒng),所以這里討論的要點適用于所有的編程語言和編程環(huán)境,比如:VB、VBScript、VC、Java等等。

顯式的定義對象變量的類型:

實際上,這條準(zhǔn)則不僅適用于ADO編程,也適用于其他的COM對象相關(guān)的編程,因為如果一開始就定義變量類型的話,編譯器在編譯的時候就可以知道變量的類型,編譯器實際上就采用vtable偏移的方式來得到具體的COM對象包含的方法的地址(這一點和C 中的虛函數(shù)的地址的獲取類似),但如果一開始不指定變量類型的話,比如簡單的采用如下的語句:

DIM myCon as Object

或者是

DIM myCon

那么編譯器在編譯的時候就不能得到變量的類型,而只能在運(yùn)行的時候動態(tài)的得到方法的信息(通過使用接口IDispatch的方法Invoke來實現(xiàn)的),這樣為了得到方法的地址和相關(guān)的變量情況就需要在內(nèi)部進(jìn)行兩次調(diào)用,無疑就使速度降低。

當(dāng)瀏覽記錄的時候,綁定列到具體的字段對象上去

這個意思就是說在一開始的時候我們就建立對字段對象的引用,避免在每次得到記錄的時候需要在Rcordset::Fields中進(jìn)行查找而增加系統(tǒng)的開銷。

比如可以采用如下的示例代碼形式:

以下為引用的內(nèi)容:

  Private Sub TblBrowse_Click()

   Dim fld1 As ADODB.Field

   Dim fld2 As ADODB.Field

   Dim rs As ADODB.Recordset

   set rs=g_cn.execute(...) g_cn為全局adodb.connection對象

   Set fld1 = rs.Fields("id") 數(shù)據(jù)表的字段

   Set fld2 = rs.Fields("name") 數(shù)據(jù)表的字段
   If rs.BOF = False Then

    While rs.BOF = False

     Debug.Print fld1.Value

     Debug.Print fld2.Value

     rs.MoveNext

    Wend

   End If

   rs.Close

  End Sub

盡量采用SQL語句和存儲過程進(jìn)行數(shù)據(jù)更新

盡管采用Recordset對象來更新數(shù)據(jù)是非常方便的,但是它的開銷也更大,所以如果可能的話,就要采用SQL語句來更新數(shù)據(jù)。使用存儲過程而不是單一的SQL語句來獲取信息。因為存儲過程是在服務(wù)器端執(zhí)行的,只把結(jié)果返回到客戶端,這樣一方面可以降低網(wǎng)絡(luò)進(jìn)行數(shù)據(jù)交互的開銷,另一方面使系統(tǒng)更加容易維護(hù),并且保持?jǐn)?shù)據(jù)的一致性。而如果使用recordset來得到結(jié)果的話,通過數(shù)據(jù)源對象返回的查詢集不僅包含了數(shù)據(jù),而且也包含了元數(shù)據(jù)(metadata),在有些時候元數(shù)據(jù)可能比數(shù)據(jù)本身還要大,這樣系統(tǒng)的開銷無疑也增加了不少。

如果必須要使用游標(biāo)的話,最好使用集合的方法對單條的SELECT語句進(jìn)行操作

Recordset::get_Collect和Recordset::put_Collect方法是Recordset 對象的快捷方式,可以使你快速的得到一個字段的值而不需要獲得關(guān)于一個字段的引用。可以參考如下的示例代碼:

以下為引用的內(nèi)容:

  Sub Collect()

   Dim rs As New Recordset

   rs.ActiveConnection = "…"

   rs.Source = "一條SQL查詢語句"

   rs.Open

   Debug.Print rs.Collect(0), rs.Collect(1), rs.Collect(2)

   Debug.Print rs!au_id, rs!au_fname, rs!au_lname

  End Sub

只查詢你所需要的數(shù)據(jù)

盡管很多開發(fā)人員都習(xí)慣采用"SELECT * FROM TBL"的模式進(jìn)行查詢,但是為了提高系統(tǒng)的效率,如果你只需要其中某幾個字段的值的話,最好把這幾個字段直接寫出來,同時需要限定返回記錄集的范圍(通過WHERE子句進(jìn)行限定)

正確選擇游標(biāo)的位置、類型和鎖方式

如果你只需要按順序讀取記錄并且不需要滾動和更新記錄的話,使用服務(wù)器端游標(biāo)(adUseServer)、僅向前游標(biāo)(adOpenForwardOnly)和讀鎖(adLockReadOnly)可以使你獲得最好的性能。如果你需要滾動記錄的話,采用客戶端游標(biāo)(adUseServer)會比采用服務(wù)器端游標(biāo)所得到的性能要好,ADO系統(tǒng)默認(rèn)是采用服務(wù)器端游標(biāo)類型的。當(dāng)然如果數(shù)據(jù)集合相當(dāng)大的話,采用服務(wù)器端游標(biāo)的性能會好一些。同時需要注意的話,如果采用客戶端游標(biāo)的話,最好只采用讀加鎖(adLockReadOnly)的鎖類型,因為如果你需要更新數(shù)據(jù)的話,客戶端游標(biāo)引擎需要得到額外的信息(元數(shù)據(jù)),而這個信息的獲取是非常昂貴的。

調(diào)整記錄集對象(Recordset)CacheSize的屬性

ADO使用記錄集對象的CacheSize的屬性來決定提取和緩存的記錄的數(shù)目,當(dāng)你在緩存的范圍內(nèi)瀏覽數(shù)據(jù)的話,ADO就只從緩存中提取數(shù)據(jù)。當(dāng)你要瀏覽的數(shù)據(jù)超出緩存的范圍的時候,ADO就釋放緩存,提取下一些記錄(提取的數(shù)目為CacheSize的大小)。你必須根據(jù)你具體的應(yīng)用程序的情況來設(shè)定CacheSize的大小保證你得到最好的性能。

自己定義command對象的參數(shù)

在許多數(shù)據(jù)源中,得到參數(shù)信息和執(zhí)行命令的代價幾乎是一樣的,所以如果可能的話,你要自己在程序中定義好command參數(shù)(也就是說要定義好參數(shù)的名稱、類型和方向信息),而避免從數(shù)據(jù)提供者(Provider)那里獲取信息.

使用原始的OLE DB提供者

MDAC對許多數(shù)據(jù)源提供了原始的數(shù)據(jù)提供者,比如SQL Server,Oracle和ACCESS數(shù)據(jù)庫,這樣你不需要再通過ODBC來獲取數(shù)據(jù)(也就是說不需要再通過ODBC驅(qū)動這一層),這樣的好處是你能更快的得到數(shù)據(jù),并且降低磁盤和內(nèi)存的開銷。

如果使用客戶端游標(biāo)的話,斷開connection連接

ADO有一個特征是當(dāng)使用客戶端游標(biāo)操作Recordset記錄集的時候,不需要和服務(wù)器進(jìn)行聯(lián)系。你可以充分利用這個特征降低服務(wù)器端的開銷(服務(wù)器就不需要維護(hù)這些連接了),當(dāng)你操作完記錄集需要更新的話,可以重新和數(shù)據(jù)庫進(jìn)行連接來更新數(shù)據(jù)。為了創(chuàng)建一個可以斷開連接的記錄集,你同時也需要使用靜態(tài)游標(biāo)(adOpenStatic)和批處理的加鎖模式(adLockBatchOptimistic)。下面的示例是用VC寫的:

以下為引用的內(nèi)容:

……

  pRs.CreateInstance(__uuid(Recordset));

  pRs->CursorLoction=adUseClient;

  pRs->Open(strCmdText,strConnection,adOpenStatic,adLockBatchOptimistic,adCmdText);

  pRs->PutRefActiveConnection(NULL);

  file://這里可以對記錄集對象pRs進(jìn)行操作

  pRs->PutRefAxctiveConnection(pCon); file://重新和數(shù)據(jù)庫建立連接

  pRs->UpdateBatch(adAffectAll); file://批量更新數(shù)據(jù)

需要注意的是,當(dāng)你執(zhí)行批量更新的話,你必須自己處理數(shù)據(jù)沖突問題,因為當(dāng)你更新數(shù)據(jù)的時候,其他人可能也正在對該數(shù)據(jù)進(jìn)行操作。

如果不需要返回記錄的話,使用adExecuteNoRecords選項

ADO 2.0包括一個新的執(zhí)行選項稱為adExecuteNoRecords,當(dāng)使用該選項的時候,ADO就不會創(chuàng)建記錄集對象,不設(shè)置任何游標(biāo)屬性。數(shù)據(jù)提供者因為不需要認(rèn)證行集合的屬性而使性能得到優(yōu)化。具體的例子如下:

con.Execute "insert into tbl values(fv1, fv2) ", , adExecuteNoRecords

對僅有一條的執(zhí)行語句采用Connection::Execute的方法比使用Recordset::Open或者是Command::Execute的效果要好,因為ADO不保留任何命令狀態(tài)的信息,因此執(zhí)行性能就有所改進(jìn)。

使用session/connection緩沖池

我們知道,數(shù)據(jù)庫的打開和關(guān)閉是很消耗系統(tǒng)資源的。因此,連接池對基于多層的應(yīng)用的性能有很大的提高,當(dāng)你使用MDAC的時候,開發(fā)人員本身并不需要考慮對數(shù)據(jù)庫連接的緩存,MDAC會自動處理它。連接池在兩個層次上提供支持,OLE DB sessions和ODBC連接。如果你使用ADO的話,你的數(shù)據(jù)庫連接會自動被OLE DB session緩沖池所緩存。如果使用ODBC的話,在ODBC數(shù)據(jù)源管理中新的連接緩沖池選項可以讓你對ODBC緩沖進(jìn)行設(shè)置,然后ODBC驅(qū)動程序會為你做剩下的事情。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 普兰县| 福安市| 河曲县| 巩留县| 吐鲁番市| 诏安县| 仁怀市| 长葛市| 弥勒县| 绿春县| 兴义市| 潞西市| 晴隆县| 扬中市| 沧州市| 色达县| 登封市| 甘泉县| 德江县| 汉阴县| 徐州市| 白水县| 茶陵县| 民乐县| 金堂县| 平和县| 辽中县| 临朐县| 内黄县| 民权县| 井研县| 福清市| 抚顺市| 昭平县| 登封市| 连州市| 离岛区| 肃南| 交城县| 宿迁市| 广平县|