久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

ACCESS 調(diào)用后臺(tái)存儲(chǔ)過(guò)程的實(shí)現(xiàn)方法

瀏覽:146日期:2023-03-18 16:41:49
但是,它要對(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ù)人員修改用戶(hù)的電表讀數(shù)后,激活計(jì)算電費(fèi)的觸發(fā)器,能立即重新計(jì)算該用戶(hù)的電費(fèi)。這樣子,既可以和批量計(jì)算電費(fèi)共享同一程序,不用在Access端重新開(kāi)發(fā),有可以加快前端的響應(yīng)速度。
  三、 以上二種方法,只可以說(shuō)是間接調(diào)用后臺(tái)存儲(chǔ)過(guò)程,Access還提供一種直接調(diào)用的方法,可以用Access 傳遞查詢(xún)直接將命令發(fā)送到數(shù)據(jù)庫(kù)服務(wù)器。
  建立Access 傳遞查詢(xún)步驟如下:
  (1) 在數(shù)據(jù)庫(kù)窗口中單擊“查詢(xún)”選項(xiàng)卡,然后單擊“新建”按鈕。
  (2) 在“新建查詢(xún)”對(duì)話框中單擊“設(shè)計(jì)視圖”選項(xiàng),然后單擊“確定”按鈕。
  (3) 在“顯示表”對(duì)話框內(nèi)單擊“關(guān)閉”按鈕。
  (4) 在“查詢(xún)”菜單上,指到“SQL 語(yǔ)句條件”,然后單擊“傳遞”命令。
  (5) 在工具欄上,請(qǐng)單擊“屬性”按鈕 以顯示查詢(xún)屬性表。
  (6) 在查詢(xún)屬性表中,請(qǐng)?jiān)O(shè)置“ODBC 連接字符串”屬性來(lái)指定要連接的數(shù)據(jù)庫(kù)信息。可以輸入連接信息: ”O(jiān)DBC;DSN=ntserver0;UID=sa;PWD=;DATABASE=BMS”,或用“生成器”按鈕生成。
  (7) 因存儲(chǔ)過(guò)程不用返回記錄,所以將“返回記錄”屬性設(shè)置為“否”。
  (8) 在“SQL 傳遞查詢(xún)”窗口中,輸入傳遞查詢(xún): exec statistics。Statistics 是SQL Server 數(shù)據(jù)庫(kù)的一個(gè)存儲(chǔ)過(guò)程。
  (9) 關(guān)閉查詢(xún),保存查詢(xún)?yōu)椋簊tat_query。
  運(yùn)行傳遞查詢(xú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
  "打開(kāi)上面建的傳遞查詢(xún)stat_query
  Set qdf = dbs.OpenQueryDef("stat_query ")
  qdf.Execute
  Set dbs = Nothing
  End Sub
  這種方法在SQL Server 6.5 中實(shí)現(xiàn)完全沒(méi)問(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ù)處理能力。
標(biāo)簽: Access
相關(guān)文章:
主站蜘蛛池模板: 灵寿县| 义乌市| 嘉禾县| 天祝| 浮梁县| 都兰县| 昌邑市| 共和县| 阜康市| 资阳市| 图们市| 宣威市| 凤山市| 壤塘县| 南川市| 六枝特区| 中山市| 怀仁县| 夏邑县| 渭源县| 安平县| 台前县| 西昌市| 罗田县| 中牟县| 白水县| 徐州市| 方城县| 新源县| 绍兴县| 万源市| 陆川县| 南安市| 宁德市| 正定县| 赤水市| 昌图县| 沧州市| 南平市| 唐山市| 多伦县|