亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Access > 正文

數據庫應用程序需注意的問題

2024-09-07 19:03:38
字體:
來源:轉載
供稿:網友

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

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

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

DIM myCon as Object

或者是

DIM myCon

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

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

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

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

以下為引用的內容:

  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") 數據表的字段

   Set fld2 = rs.Fields("name") 數據表的字段
   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語句和存儲過程進行數據更新

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

如果必須要使用游標的話,最好使用集合的方法對單條的SELECT語句進行操作

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

以下為引用的內容:

  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

只查詢你所需要的數據

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

正確選擇游標的位置、類型和鎖方式

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

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

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

自己定義command對象的參數

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

使用原始的OLE DB提供者

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

如果使用客戶端游標的話,斷開connection連接

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

以下為引用的內容:

……

  pRs.CreateInstance(__uuid(Recordset));

  pRs->CursorLoction=adUseClient;

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

  pRs->PutRefActiveConnection(NULL);

  file://這里可以對記錄集對象pRs進行操作

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

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

需要注意的是,當你執行批量更新的話,你必須自己處理數據沖突問題,因為當你更新數據的時候,其他人可能也正在對該數據進行操作。

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

ADO 2.0包括一個新的執行選項稱為adExecuteNoRecords,當使用該選項的時候,ADO就不會創建記錄集對象,不設置任何游標屬性。數據提供者因為不需要認證行集合的屬性而使性能得到優化。具體的例子如下:

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

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

使用session/connection緩沖池

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品狠狠操| 奇米一区二区三区四区久久| 亚洲精品国产精品国自产在线| 亚洲日本aⅴ片在线观看香蕉| 久久久久久久网站| 亚洲欧美一区二区三区情侣bbw| 亚洲一区二区久久久久久久| 欧美日韩xxxxx| 久久99热这里只有精品国产| 欧美性受xxxx黑人猛交| 日韩av在线播放资源| 5278欧美一区二区三区| 992tv在线成人免费观看| 日韩在线观看免费网站| 国产欧美日韩视频| 性色av一区二区咪爱| 在线a欧美视频| 久久精品亚洲热| 亚洲最大福利网| xxxxx91麻豆| 亚洲一区二区三区视频| 国产专区精品视频| 午夜精品99久久免费| 中文国产亚洲喷潮| 久久九九亚洲综合| 精品美女永久免费视频| 久久影院在线观看| 国产精品日韩在线一区| 日本电影亚洲天堂| 国产精品久久久精品| 国产欧美一区二区三区在线看| 福利精品视频在线| 激情懂色av一区av二区av| 亚洲一区二区三区香蕉| 久久久久久久久久久免费精品| 成人精品视频99在线观看免费| 欧美黑人国产人伦爽爽爽| 亚洲高清久久网| 最近中文字幕2019免费| 成人情趣片在线观看免费| 亚洲精品999| 欧美日韩高清区| 国产精品爽黄69| 欧美成人全部免费| 亚洲一区二区在线| 欧美精品免费看| 欧美电影免费在线观看| 日韩中文字幕久久| 成人av资源在线播放| 国产精品看片资源| 国产精品久久999| 久久99久久久久久久噜噜| 欧美激情一区二区三区成人| 国产精品一区二区3区| 51精品国产黑色丝袜高跟鞋| 日韩精品视频观看| 91精品国产91久久| 欧美极品欧美精品欧美视频| 国产精品免费久久久久久| 日韩成人网免费视频| 欧美亚洲另类激情另类| 亚洲精品一区久久久久久| 久久精品亚洲94久久精品| 永久555www成人免费| 亚洲女人天堂色在线7777| 国内精品免费午夜毛片| 国产美女久久精品香蕉69| 91地址最新发布| 亚洲аv电影天堂网| 国产成人精品电影| 国产精品91久久| 77777少妇光屁股久久一区| 精品动漫一区二区| 日韩亚洲综合在线| 日韩免费精品视频| 久久久久久久久综合| 色综久久综合桃花网| 精品亚洲一区二区三区四区五区| 91深夜福利视频| 久久视频中文字幕| 欧美性jizz18性欧美| 美日韩在线视频| 亚洲自拍偷拍一区| 狠狠色噜噜狠狠狠狠97| 日本三级久久久| 一区二区在线视频| 久久久久久国产精品| 精品动漫一区二区| 97色在线播放视频| 欧洲美女7788成人免费视频| 日本成人在线视频网址| 亚洲激情视频在线观看| 美女av一区二区三区| 亚洲自拍另类欧美丝袜| 成人午夜小视频| 国产日韩av高清| 国产精品69精品一区二区三区| 激情懂色av一区av二区av| 九九视频这里只有精品| 亚洲国产成人一区| 久久视频在线观看免费| 中文字幕亚洲自拍| 美女扒开尿口让男人操亚洲视频网站| 国产日韩av在线播放| 国产精品第10页| 国产精品色悠悠| 大伊人狠狠躁夜夜躁av一区| 亚洲欧美日韩在线一区| 亚洲а∨天堂久久精品9966| 国产一区av在线| y97精品国产97久久久久久| 秋霞成人午夜鲁丝一区二区三区| 欧美黄色www| 性夜试看影院91社区| www欧美日韩| 亚洲成人a级网| 欧美大全免费观看电视剧大泉洋| 成人性生交xxxxx网站| 久久精品视频播放| 国产精品久久久久久久久久ktv| 国产精品福利网| 国产精品久久综合av爱欲tv| 欧美性xxxx18| 国产精品久久久一区| 91精品国产综合久久香蕉最新版| 亚洲精品网址在线观看| 日韩av中文字幕在线免费观看| 欧美俄罗斯性视频| 夜夜嗨av一区二区三区免费区| 欧美大尺度激情区在线播放| 成人性生交大片免费观看嘿嘿视频| 国产香蕉97碰碰久久人人| 国产精品久久91| 激情成人中文字幕| 久久成年人视频| 亚洲第一中文字幕在线观看| 久久久成人的性感天堂| 日韩在线视频中文字幕| 亚洲欧美国产精品专区久久| 蜜月aⅴ免费一区二区三区| 久久精品99国产精品酒店日本| 国产精品中文字幕在线观看| 欧美成人免费全部观看天天性色| 国产免费观看久久黄| 亚洲精品国产电影| 成人在线视频福利| 亚洲精品乱码久久久久久按摩观| 日本精品久久中文字幕佐佐木| 亚洲欧美日韩一区二区在线| 国产精品国语对白| 国产精品激情av电影在线观看| 色老头一区二区三区在线观看| 黑人狂躁日本妞一区二区三区| 亚洲天堂第一页| 亚洲日韩中文字幕| 亚洲激情视频在线观看| 国产精品日韩在线一区| 韩国一区二区电影| 欧美日韩国产二区| 自拍偷拍免费精品| 久久亚洲精品中文字幕冲田杏梨| 成人黄色在线观看| 日日狠狠久久偷偷四色综合免费| 性欧美长视频免费观看不卡|