傳遞查詢的例子-在ACCESS中通過傳遞查詢調(diào)用Sql server後颱存儲(chǔ)過程
- 2004-01-16 18:28:00
- zhengjialon-Office交流網(wǎng) 原創(chuàng)
- 7287
問題(網(wǎng)友:Tom_HYQ)
我希望學(xué)學(xué)Access的傳遞查詢,可惜MS的help上沒有相關(guān)的例子,請(qǐng)高手們多多指教瞭。
謝謝。
解答( zhengjialon):
在ACCESS中使用傳遞查詢調(diào)用後颱存儲(chǔ)過程
週傑 提供
ACCESS是一箇Client/Server的優(yōu)秀前端開髮工具,具有易學(xué)易用,界麵友好,開髮簡(jiǎn)單,和其他數(shù)據(jù)庫(kù)接口靈活。但是,牠要對(duì)大量數(shù)據(jù)處理時(shí),速度比較慢。深圳供電局現(xiàn)有60萬(wàn)用戶,下麵有6箇營(yíng)業(yè)所,通過64K DDN 和局相連,如果有一箇營(yíng)業(yè)所要對(duì)1萬(wàn)用戶進(jìn)行處理的話,要花2~3小時(shí),嚴(yán)重影響其他業(yè)務(wù)的開展。所以,當(dāng)有大量數(shù)據(jù)需要處理時(shí),不能在Client端處理,而必鬚在Server端處理。 但ACCESS和Server端之間多數(shù)通過ODBC來(lái)連接,這樣就增加瞭調(diào)用後颱存儲(chǔ)過程的難度。筆者通過在實(shí)際工作中長(zhǎng)期的摸索,根據(jù)不衕的業(yè)務(wù)需要,可以用下麵三種方法去調(diào)用後颱存儲(chǔ)過程。
一、 Access 曏後颱提交作業(yè),這一箇箇作業(yè)對(duì)應(yīng)一箇箇的存儲(chǔ)過程。在SQL Server 6.5中,通過Task Manager 來(lái)建立相應(yīng)的Task; 而在Oracle 8.0中,通過Managing Job Queue 來(lái)建立相應(yīng)的Job。在Access中,在job_list錶中插入一箇作業(yè),這些作業(yè)一般每天晚上運(yùn)行一次。這些作業(yè)對(duì)應(yīng)的業(yè)務(wù)一般是需要處理非常大量數(shù)據(jù),而實(shí)時(shí)性又是較低的,在我們的業(yè)務(wù)中比較典型的例子是每天晚上大量的電費(fèi)計(jì)祘。
二、 在Server端建立一些觸髮器(Trigger),在Access中激活這些觸髮器。在SQL Server 6.5 和Oracle 8.0中,都是通過Create Trigger 來(lái)實(shí)現(xiàn)。在Access中,根據(jù)不衕的業(yè)務(wù),通過插入、修改、刪除記録來(lái)激活不衕觸髮器。在我們的業(yè)務(wù)中一箇例子是,當(dāng)業(yè)務(wù)人員修改用戶的電錶讀數(shù)後,激活計(jì)祘電費(fèi)的觸髮器,能立卽重新計(jì)祘該用戶的電費(fèi)。這樣子,旣可以和批量計(jì)祘電費(fèi)共享衕一程序,不用在Access端重新開髮,有可以加快前端的響應(yīng)速度。
三、 以上二種方法,隻可以説是間接調(diào)用後颱存儲(chǔ)過程,Access還提供一種直接調(diào)用的方法,可以用Access 傳遞查詢直接將命令髮送到數(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接信息: ”O(jiān)DBC;DSN=ntserver0;UID=sa;PWD=;DATABASE=BMS”,或用“生成器”按鈕生成。
(7) 因存儲(chǔ)過程不用返迴記録,所以將“返迴記録”屬性設(shè)置爲(wèi)“否”。
(8) 在“SQL 傳遞查詢”窗口中,輸入傳遞查詢: exec statistics。Statistics 是SQL Server 數(shù)據(jù)庫(kù)的一箇存儲(chǔ)過程。
(9) 關(guān)閉查詢,保存查詢爲(wèi):stat_query。
運(yùn)行傳遞查詢的方法有:
(1) 用Microsoft Access的宏 OpenQuery。
(2) 用下麵的事件過程:
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)完全沒問題,在Oracle 8.0中不能實(shí)現(xiàn),錯(cuò)誤信息爲(wèi):ORA-00900 invalid SQL statement. 由於這種方法不需要一箇中間的錶去排隊(duì)或激活後颱存儲(chǔ)過程,所以牠的應(yīng)用麵就很廣,凡是需要處理大量數(shù)據(jù)的業(yè)務(wù),都可以放到Server端去處理,如統(tǒng)計(jì)報(bào)錶。
通過以上三種方法,解決瞭Access對(duì)大量數(shù)據(jù)處理速度慢的弱點(diǎn),大大加大瞭深圳供電局?jǐn)?shù)據(jù)處理能力。
zhengjialon
本示例使用直接傳遞查詢從 Microsoft Access 版本的 Northwind 示例數(shù)據(jù)庫(kù)中檢索結(jié)果集。
SELECT *
FROM OpenRowset('Microsoft.Jet.OLEDB.4.0',
'c:\northwind.mdb';'admin'; '',
'SELECT CustomerID, CompanyName
FROM Customers
WHERE Region = ''WA'' ')
Tom_HYQ
謝謝版主,看瞭你的幫助,我有瞭一點(diǎn)認(rèn)識(shí)
是不是可以這樣理解:(我説得不對(duì),請(qǐng)糾正)
傳遞查詢主要用於通過access曏後颱數(shù)據(jù)庫(kù)髮命令,讓數(shù)據(jù)庫(kù)進(jìn)行相關(guān)操作,把相關(guān)的數(shù)據(jù)集返迴到access中。因爲(wèi)access隻是髮送命令而沒有必要與後颱數(shù)據(jù)庫(kù)進(jìn)行數(shù)據(jù)訪問,所以速度比較快。
我有幾點(diǎn)不明白
有沒有一箇例子是返迴記録集的?(如果想訪問後颱數(shù)據(jù)庫(kù)以返迴記録,用傳遞查詢閤適嗎?還是用odbc鏈接錶的方式更有效?)
直接使用你的第二箇例子時(shí),access齣錯(cuò),説不能返迴一箇MS jet的數(shù)據(jù)庫(kù),是什麼迴事?
zhengjialon
第二箇示例可能不能在ACCESS中運(yùn)行
(相關(guān)查詢-相關(guān)文章技巧鏈接):
ACCESS與SQL SERVER繫列之二—MSDE部署-免費(fèi)Access培訓(xùn)公開課[4]
在 Access 中使用“存儲(chǔ)過程”(一)
Access無(wú)需DSN文件快速連接SQL Server的方法!
- office課程播放地址及課程明細(xì)
- Excel Word PPT Access VBA等Office技巧學(xué)習(xí)平颱
- 將( .accdb) 文件格式數(shù)據(jù)庫(kù)轉(zhuǎn)換爲(wèi)早期版本(.mdb)的文件格式
- 將早期的數(shù)據(jù)庫(kù)文件格式(.mdb)轉(zhuǎn)換爲(wèi) (.accdb) 文件格式
- KB5002984:配置 Jet Red Database Engine 數(shù)據(jù)庫(kù)引擎和訪問連接引擎以阻止對(duì)遠(yuǎn)程數(shù)據(jù)庫(kù)的訪問(remote table)
- Access 365 /Access 2019 數(shù)據(jù)庫(kù)中哪些函數(shù)功能和屬性被沙箱模式阻止(如未啟動(dòng)宏時(shí))
- Access Runtime(運(yùn)行時(shí))最全的下載(2007 2010 2013 2016 2019 Access 365)
- access vba代碼太長(zhǎng),換行,分行的寫法
- VB6 VBA Access真正可用併且完美支持中英文的 URLEncode 與 URLDecode 函數(shù)源碼
- 自定義VB中的urlencode函數(shù),將URL中特殊部分進(jìn)行編碼
- Access 函數(shù)簡(jiǎn)化串接sql字符串,減少符號(hào)導(dǎo)緻的書寫錯(cuò)誤
- vba完全關(guān)閉IE瀏覽器及調(diào)用IE瀏覽器的簡(jiǎn)單應(yīng)用
- 利用FollowHyperlink方法打開超鏈接提示“無(wú)法下載您要求的信息”的解決方案
- 在access中用代碼打開文本框中超鏈接地址
- Activex控件或Dll 在某些電腦無(wú)法正常註冊(cè)的解決辦法(regsvr32註冊(cè)時(shí)卡?。?/a>
- office使用部分控件時(shí)提示“您沒有使用該ActiveX控件許可的問題”的解決方法
- RTF文件(富文本格式)的一些解析
- Access樹控件(treeview) 64位Office下齣現(xiàn)橫曏滾動(dòng)條不會(huì)自動(dòng)定位的解決辦法
- Access中國(guó)樹控件 在win10電腦 節(jié)點(diǎn)行間距太小的解決辦法
- EXCEL 2019 64位版(Office 2019 64位)早就支持64位Treeview 樹控件 ListView列錶等64位MSCOMMCTL.OCX控件下載
- VBA或VB6調(diào)用WebService(直接Post方式)併解析返迴的XML
- 早期PB程序連接Sqlserver齣現(xiàn)錯(cuò)誤
- MMC 不能打開文件C:/Program Files/Microsoft SQL Server/80/Tools/Binn/SQL Server Enterprise Manager.MSC 可能是由於文件不存在,不是一箇MMC控製颱,或者用後來(lái)的MMC版
- sql server連接不瞭的解決辦法
- localhost與127.0.0.1區(qū)彆
- Roych的淺談數(shù)據(jù)庫(kù)開髮繫列(Sql Server)
- sqlserver 自動(dòng)備份對(duì)備份目録沒有存取權(quán)限的解決辦法
- 安裝Sql server 2005 express 和SQLServer2005 Express版企業(yè)管理器 SQLServer2005_SSMSEE
聯(lián)繫人: | 王先生 |
---|---|
Email: | 18449932@qq.com |
QQ: | 18449932 |
微博: | officecn01 |