ACCESS中調用後台預存程序

來源:互聯網
上載者:User
ACCESS是一個Client/Server的優秀前端開發工具,具有易學易用,介面友好,開發簡單,和其他資料庫介面靈活。

但是,它要對大量資料處理時,速度比較慢。當有大量資料需要處理時,不能在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對大量資料處理速度慢的弱點,大大加大了深圳供電局資料處理能力。



相關文章

Beyond APAC's No.1 Cloud

19.6% IaaS Market Share in Asia Pacific - Gartner IT Service report, 2018

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。