如何在ACCESS中調(diào)用后臺(tái)存儲(chǔ)_Access數(shù)據(jù)庫(kù)教程
推薦:如何將Access升級(jí)為SQL Server 2005第一步:配置數(shù)據(jù)源 1.在控制面板管理工具里選擇數(shù)據(jù)源,在彈出的頁(yè)面選擇用戶DSN(默認(rèn))。 2.點(diǎn)擊旁邊的添加按鈕,在彈出的頁(yè)面選擇Driver do Microsoft Access (*.mdb),然后點(diǎn)擊完成。 3.在彈出的ODBC Microsoft Accecc 安裝頁(yè)面,在數(shù)據(jù)源名文本輸入框填寫
ACCESS是一個(gè)Client/Server的優(yōu)秀前端開發(fā)工具,具有易學(xué)易用,界面友好,開發(fā)簡(jiǎn)單,和其他數(shù)據(jù)庫(kù)接口靈活。但是,它要對(duì)大量數(shù)據(jù)處理時(shí),速度比較慢。當(dāng)有大量數(shù)據(jù)需要處理時(shí),不能在Client端處理,而必須在Server端處理。 但ACCESS和Server端之間多數(shù)通過(guò)ODBC來(lái)連接,這樣就增加了調(diào)用后臺(tái)存儲(chǔ)過(guò)程的難度。筆者通過(guò)在實(shí)際工作中長(zhǎng)期的摸索,根據(jù)不同的業(yè)務(wù)需要,可以用下面三種方法去調(diào)用后臺(tái)存儲(chǔ)過(guò)程。
一、 Access 向后臺(tái)提交作業(yè),這一個(gè)個(gè)作業(yè)對(duì)應(yīng)一個(gè)個(gè)的存儲(chǔ)過(guò)程。在SQL Server 6.5中,通過(guò)Task Manager 來(lái)建立相應(yīng)的Task; 而在Oracle 8.0中,通過(guò)Managing Job Queue 來(lái)建立相應(yīng)的Job。在Access中,在job_list表中插入一個(gè)作業(yè),這些作業(yè)一般每天晚上運(yùn)行一次。這些作業(yè)對(duì)應(yīng)的業(yè)務(wù)一般是需要處理非常大量數(shù)據(jù),而實(shí)時(shí)性又是較低的,在我們的業(yè)務(wù)中比較典型的例子是每天晚上大量的電費(fèi)計(jì)算。
二、 在Server端建立一些觸發(fā)器(Trigger),在Access中激活這些觸發(fā)器。在SQL Server 6.5 和Oracle 8.0中,都是通過(guò)Create Trigger 來(lái)實(shí)現(xiàn)。在Access中,根據(jù)不同的業(yè)務(wù),通過(guò)插入、修改、刪除記錄來(lái)激活不同觸發(fā)器。在我們的業(yè)務(wù)中一個(gè)例子是,當(dāng)業(yè)務(wù)人員修改用戶的電表讀數(shù)后,激活計(jì)算電費(fèi)的觸發(fā)器,能立即重新計(jì)算該用戶的電費(fèi)。這樣子,既可以和批量計(jì)算電費(fèi)共享同一程序,不用在Access端重新開發(fā),有可以加快前端的響應(yīng)速度。
三、 以上二種方法,只可以說(shuō)是間接調(diào)用后臺(tái)存儲(chǔ)過(guò)程,Access還提供一種直接調(diào)用的方法,可以用Access 傳遞查詢直接將命令發(fā)送到數(shù)據(jù)庫(kù)服務(wù)器。
建立Access 傳遞查詢步驟如下:
(1) 在數(shù)據(jù)庫(kù)窗口中單擊“查詢”選項(xiàng)卡,然后單擊“新建”按鈕。
(2) 在“新建查詢”對(duì)話框中單擊“設(shè)計(jì)視圖”選項(xiàng),然后單擊“確定”按鈕。
(3) 在“顯示表”對(duì)話框內(nèi)單擊“關(guān)閉”按鈕。
(4) 在“查詢”菜單上,指到“SQL 語(yǔ)句條件”,然后單擊“傳遞”命令。
(5) 在工具欄上,請(qǐng)單擊“屬性”按鈕 以顯示查詢屬性表。
(6) 在查詢屬性表中,請(qǐng)?jiān)O(shè)置“ODBC 連接字符串”屬性來(lái)指定要連接的數(shù)據(jù)庫(kù)信息�?梢暂斎脒B接信息: ”ODBC;DSN=ntserver0;UID=sa;PWD=;DATABASE=BMS”,或用“生成器”按鈕生成。
(7) 因存儲(chǔ)過(guò)程不用返回記錄,所以將“返回記錄”屬性設(shè)置為“否”。
(8) 在“SQL 傳遞查詢”窗口中,輸入傳遞查詢: exec statistics。Statistics 是SQL Server 數(shù)據(jù)庫(kù)的一個(gè)存儲(chǔ)過(guò)程。
(9) 關(guān)閉查詢,保存查詢?yōu)椋簊tat_query。
運(yùn)行傳遞查詢的方法有:
(1) 用Microsoft Access的宏 OpenQuery。
(2) 用下面的事件過(guò)程:
Private Sub 統(tǒng)計(jì)_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 中實(shí)現(xiàn)完全沒問(wèn)題,在Oracle 8.0中不能實(shí)現(xiàn),錯(cuò)誤信息為:ORA-00900 invalid SQL statement. 由于這種方法不需要一個(gè)中間的表去排隊(duì)或激活后臺(tái)存儲(chǔ)過(guò)程,所以它的應(yīng)用面就很廣,凡是需要處理大量數(shù)據(jù)的業(yè)務(wù),都可以放到Server端去處理,如統(tǒng)計(jì)報(bào)表。
通過(guò)以上三種方法,解決了Access對(duì)大量數(shù)據(jù)處理速度慢的弱點(diǎn),大大加大了深圳供電局?jǐn)?shù)據(jù)處理能力。
分享:Access數(shù)據(jù)庫(kù)壓縮失敗的原因壓縮數(shù)據(jù)庫(kù)文件可以提高數(shù)據(jù)庫(kù)的性能,但是有些時(shí)候在壓縮數(shù)據(jù)庫(kù)時(shí),系統(tǒng)會(huì)提醒用戶該數(shù)據(jù)庫(kù)不能壓縮。如果在Access數(shù)據(jù)庫(kù)中刪除數(shù)據(jù)庫(kù)對(duì)象,或者在Access項(xiàng)目中刪除對(duì)象,Access數(shù)據(jù)庫(kù)或Access項(xiàng)目可能會(huì)產(chǎn)生碎片并會(huì)降低磁盤空間的使用效率。壓縮Access數(shù)
- Access數(shù)據(jù)庫(kù)安全策略之ASP式
- 第N次被ACCESS的關(guān)鍵字涮
- Access中用Jet SQL語(yǔ)句刪除表關(guān)系
- Access報(bào)表打印如何自動(dòng)分頁(yè)
- Access完成累計(jì)余額的計(jì)算
- 搭建Access為主的Mdb數(shù)據(jù)庫(kù)
- 一句sql更新兩個(gè)表并可更新對(duì)應(yīng)的字段值具體實(shí)現(xiàn)
- MySQL查詢優(yōu)化:連接查詢排序limit(join、order by、limit語(yǔ)句)介紹
- 內(nèi)網(wǎng)ssh/mysql登錄緩慢的解決方法
- 使用準(zhǔn)則進(jìn)行條件查詢--1.4.從窗體中選擇查詢的條件
- 中文Access2000速成教程--1.1 使用“向?qū)А痹O(shè)計(jì)數(shù)據(jù)庫(kù)
- 中文Access2000速成教程--1.3 在“設(shè)計(jì)”視圖中設(shè)計(jì)表
Access數(shù)據(jù)庫(kù)教程Rss訂閱編程教程搜索
Access數(shù)據(jù)庫(kù)教程推薦
- 數(shù)據(jù)庫(kù)查詢優(yōu)化的實(shí)用技巧
- 淺析Excel和Access之間的數(shù)據(jù)交換
- 淺議ACCESS統(tǒng)計(jì)不重復(fù)記錄個(gè)數(shù)問(wèn)題
- Access轉(zhuǎn)Sql Server問(wèn)題 實(shí)例說(shuō)明
- ADODB連接access是出現(xiàn) 80004005 錯(cuò)誤的解決方法
- Word與Access數(shù)據(jù)交流技巧
- 如何在退出整個(gè)系統(tǒng)前提示用戶
- 怎樣計(jì)算Access完成累計(jì)余額
- Access作為網(wǎng)站數(shù)據(jù)庫(kù)的弊端
- 解析Access新手編號(hào)的生成問(wèn)題
猜你也喜歡看這些
- Access 執(zhí)行SQL的方法
- 如何打開老版本數(shù)據(jù)庫(kù)
- 怎樣防止Access數(shù)據(jù)庫(kù)被下載
- 談Access:數(shù)據(jù)轉(zhuǎn)換問(wèn)題
- 內(nèi)網(wǎng)ssh/mysql登錄緩慢的解決方法
- 中文Access2000速成教程--1.8 定義表之間的關(guān)系
- access的備注字段限制64K
- 數(shù)據(jù)在Access與Office組件間自由流動(dòng)
- 如何讓access自動(dòng)編號(hào)從1開始排序?qū)崿F(xiàn)方法
- access數(shù)據(jù)庫(kù)用sql語(yǔ)句添加字段,修改字段,刪除字段
- 相關(guān)鏈接:
- 教程說(shuō)明:
Access數(shù)據(jù)庫(kù)教程-如何在ACCESS中調(diào)用后臺(tái)存儲(chǔ)
。