但是,它要對大量數據處理時,速度比較慢。當有大量數據需要處理時,不能在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對大量數據處理速度慢的弱點,大大加大了深圳供電局數據處理能力。
ACCESS 調用后臺存儲過程的實現方法
2021-05-18 21:33Access教程網 Access
ACCESS是一個Client/Server的優秀前端開發工具,具有易學易用,界面友好,開發簡單,和其他數據庫接口靈活。
延伸 · 閱讀
- 2024-12-13《往日不再》復刻或將于TGA公布:后臺活動突然
- 2022-03-09MySQL存儲過程圖文實例講解
- 2022-03-09C# Ado.net實現讀取SQLServer數據庫存儲過程列表及參
- 2022-02-24SQL SERVER存儲過程用法詳解
- 2022-02-23Excel2003表格中如何導入ACCESS數據庫實現數據快速
- 2022-02-22C# 操作 access 數據庫的實例代碼
- Access
解決Access出現Microsoft JET Database Engine (0x80004005)未指定的錯誤
我們在使用access數據庫的時候,有時候會遇到Microsoft JET Database Engine (0x80004005)未指定的錯誤,一般出現這個錯誤都是權限問題,今天我們就來詳細的談下解...
- Access
Access 使用總結一篇
最近幫朋友使用Access做了個小項目。遇到了一些問題,記錄如下...
- Access
Access連接數據源(ODBC)配置(新手必知)
win7 64位旗艦版控制面板中管理工具下的數據源(ODBC)配置竟然只有SQLServer的驅動,其他的都沒有了,此問題的解決方法如下...
- Access
Sql server、access、mysql隨機提取N條記錄
本文為大家介紹Sql server、access、mysql隨機提取N條記錄的方法。有需要的朋友可以參考下...
- Access
access中顯示MSysObjects系統表的設置方法
這篇文章主要介紹了access中顯示MSysObjects系統表的設置方法,在一些特別的環境中需要顯示MSysObjects系統表,需要的朋友可以參考下...
- Access
自己動手把ACCESS轉換到SQLSERVER的方法
這篇文章主要介紹了自己動手把ACCESS轉換到SQLSERVER方法,需要的朋友可以參考下...
- Access
搭建小型access數據庫實錄
access其最大的優點是:簡單易學!非計算機專業的人員,也能學會。所以用它作為數據庫的入門來學習是非常不錯的選擇。本文主要講訴怎樣一步步搭建一...
- Access
union這個連接是有什么用的和INNER JOIN有什么區別
Inner join 是兩張表做交連后里面條件相同的部分記錄產生一個記錄集,union是產生的兩個記錄集(字段要一樣的)并在一起,成為一個新的記錄集...