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

首頁 > 開發 > 綜合 > 正文

在ACCESS 中調用后臺存儲過程

2024-07-21 02:10:49
字體:
來源:轉載
供稿:網友
 access是一個client/server的優秀前端開發工具,具有易學易用,界面友好,開發簡單,和其他數據庫接口靈活。但是,它要對大量數據處理時,速度比較慢。深圳供電局現有60萬用戶,下面有6個營業所,通過64k ddn 和局相連,如果有一個營業所要對1萬用戶進行處理的話,要花2~3小時,嚴重影響其他業務的開展。所以,當有大量數據需要處理時,不能在client端處理,而必須在server端處理。 但access和server端之間多數通過odbc來連接,這樣就增加了調用后臺存儲過程的難度。筆者通過在實際工作中長期的摸索,根據不同的業務需要,可以用下面三種方法去調用后臺存儲過程。

  一、 access 向后臺提交作業,這一個個作業對應一個個的存儲過程。在sql server 6.5中,通過task manager 來建立相應的task; 而在oracle 8.0中,通過managing job queue 來建立相應的job。在access中,在job_list表中插入一個作業,這些作業一般每天晚上運行一次。這些作業對應的業務一般是需要處理非常大量數據,而實時性又是較低的,在我們的業務中比較典型的例子是每天晚上大量的電費計算。

  二、 在server端建立一些觸發器(trigger),在access中激活這些觸發器。在sql server 6.5 和oracle 8.0中,都是通過create trigger 來實現。在access中,根據不同的業務,通過插入、修改、刪除記錄來激活不同觸發器。在我們的業務中一個例子是,當業務人員修改用戶的電表讀數后,激活計算電費的觸發器,能立即重新計算該用戶的電費。這樣子,既可以和批量計算電費共享同一程序,不用在access端重新開發,有可以加快前端的響應速度。

  三、 以上二種方法,只可以說是間接調用后臺存儲過程,access還提供一種直接調用的方法,可以用access 傳遞查詢直接將命令發送到數據庫服務器。

  建立access 傳遞查詢步驟如下:

  (1) 在數據庫窗口中單擊“查詢”選項卡,然后單擊“新建”按鈕。

  (2) 在“新建查詢”對話框中單擊“設計視圖”選項,然后單擊“確定”按鈕。

  (3) 在“顯示表”對話框內單擊“關閉”按鈕。

  (4) 在“查詢”菜單上,指到“sql 語句條件”,然后單擊“傳遞”命令。

  (5) 在工具欄上,請單擊“屬性”按鈕 以顯示查詢屬性表。

  (6) 在查詢屬性表中,請設置“odbc 連接字符串”屬性來指定要連接的數據庫信息。可以輸入連接信息: ”odbc;dsn=ntserver0;uid=sa;pwd=;database=bms”,或用“生成器”按鈕生成。

  (7) 因存儲過程不用返回記錄,所以將“返回記錄”屬性設置為“否”。

  (8) 在“sql 傳遞查詢”窗口中,輸入傳遞查詢: exec statistics。statistics 是sql server 數據庫的一個存儲過程。

  (9) 關閉查詢,保存查詢為:stat_query。

  運行傳遞查詢的方法有:

  (1) 用microsoft access的宏 openquery。

  (2) 用下面的事件過程:

private sub 統計_click()
dim dbs as database, qdf as querydef
dim tmq as dynaset
dim strsql as string

set dbs = currentdb
'打開上面建的傳遞查詢stat_query
set qdf = dbs.openquerydef("stat_query ")
qdf.execute
set dbs = nothing
end sub

  這種方法在sql server 6.5 中實現完全沒問題,在oracle 8.0中不能實現,錯誤信息為:ora-00900 invalid sql statement. 由于這種方法不需要一個中間的表去排隊或激活后臺存儲過程,所以它的應用面就很廣,凡是需要處理大量數據的業務,都可以放到server端去處理,如統計報表。

  通過以上三種方法,解決了access對大量數據處理速度慢的弱點,大大加大了深圳供電局數據處理能力。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 清苑县| 大连市| 潞西市| 伊春市| 保定市| 德安县| 乐亭县| 桦川县| 札达县| 色达县| 丹棱县| 平远县| 招远市| 凉山| 岢岚县| 亚东县| 福鼎市| 龙泉市| 新平| 侯马市| 蒙阴县| 余姚市| 稻城县| 巧家县| 榆树市| 曲靖市| 孝义市| 福贡县| 廉江市| 新津县| 巴塘县| 砀山县| 阿巴嘎旗| 商南县| 东源县| 两当县| 彰化县| 蒙城县| 江西省| 长阳| 北流市|