利用ASP實現(xiàn)事務(wù)處理的方法
在開發(fā)Web應(yīng)用時,無一例外地需要訪問數(shù)據(jù)庫,以完成對數(shù)據(jù)的查詢、插入、更新、刪除等操作。受應(yīng)用邏輯的影響,有時需要將多條數(shù)據(jù)庫操作指令組成一個工作單元(事務(wù))。在數(shù)據(jù)庫中,所謂事務(wù)是指一組邏輯操作單元,它使數(shù)據(jù)從一種狀態(tài)變換到另一種狀態(tài)。為確保數(shù)據(jù)庫中數(shù)據(jù)的一致性,應(yīng)當用離散的成組的邏輯單元操作數(shù)據(jù):當它全部完成時,數(shù)據(jù)的一致性可以保持;而當單元中的一部分操作失敗時,整個事務(wù)會被全部忽略,所有從起始點以后的操作全部退回到開始狀態(tài)。 ? ??? 實際上,在默認方式下對數(shù)據(jù)庫的每一次操作都是隱含的事務(wù)處理。本文以一個典型的用戶注冊程序為例,介紹三種利用ASP實現(xiàn)事務(wù)處理的方法:基于ASP數(shù)據(jù)庫組件的解決方法、基于數(shù)據(jù)庫內(nèi)部的事務(wù)處理機制的解決方法和基于MTS組件的解決方法。 ? ??? 程序功能 ??? 在SQL Server數(shù)據(jù)庫中建立兩個表:USER表和USERDOC表。其中USER表中存放的是注冊用戶的用戶名和密碼,USERDOC表中存放的是該注冊用戶的個人資料,并且以用戶名為索引。下面是表USER和USERDOC的定義: Create Table USER(userName varchar(30),userPasswd varchar(30)) Create Table USERDOC(userName varchar(30),Age int,Sex int,PhoneNumber varchar(20),Address varchar(50)) ? ??? 當用戶請求注冊時,ASP腳本先將用戶名和密碼插入到USER表中,然后在USERDOC表中插入用戶個人信息(年齡、性別、聯(lián)系電話和家庭住址等)。同時,應(yīng)用程序還必須保證USER表中的每一條記錄在USERDOC表中都有相應(yīng)的記錄。 ? 方法一 利用ASP內(nèi)置ADO組件中的Connection對象可以實現(xiàn)對數(shù)據(jù)庫操作的事務(wù)性處理。Connection對象的部分方法如下: ●Connection.BeginTrans方法:啟動一個事務(wù); ●Connection.CommitTrans方法:完成/提交一個事務(wù); ●Connection.RollBackTrans方法:撤消/放棄一個事務(wù)。 //啟動一個事務(wù)操作