亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > ASP > 正文

利用ASP實現事務處理的方法

2024-05-04 11:05:39
字體:
來源:轉載
供稿:網友

在web應用程序的開發中,我們都需要訪問數據庫來完成一系列的操作,今天錯新技術頻道小編就給大家介紹一下利用ASP實現事務處理的方法,希望對你學習這方面知識有所幫助。

?利用ASP實現事務處理的方法?????選擇自?AppleBBS?的?Blog??
關鍵字???利用ASP實現事務處理的方法?
出處????

受應用邏輯的影響,有時需要將多條數據庫操作指令組成一個工作單元(事務)。在數據庫中,所謂事務是指一組邏輯操作單元,它使數據從一種狀態變換到另一種狀態。為確保數據庫中數據的一致性,應當用離散的成組的邏輯單元操作數據:當它全部完成時,數據的一致性可以保持;而當單元中的一部分操作失敗時,整個事務會被全部忽略,所有從起始點以后的操作全部退回到開始狀態。?

實際上,在默認方式下對數據庫的每一次操作都是隱含的事務處理。本文以一個典型的用戶注冊程序為例,介紹三種利用ASP實現事務處理的方法:基于ASP數據庫組件的解決方法、基于數據庫內部的事務處理機制的解決方法和基于MTS組件的解決方法。?

程序功能?
在SQL?Server數據庫中建立兩個表: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表中插入用戶個人信息(年齡、性別、聯系電話和家庭住址等)。同時,應用程序還必須保證USER表中的每一條記錄在USERDOC表中都有相應的記錄。?

方法一?
利用ASP內置ADO組件中的Connection對象可以實現對數據庫操作的事務性處理。Connection對象的部分方法如下:?
●Connection.BeginTrans方法:啟動一個事務;?
●Connection.CommitTrans方法:完成/提交一個事務;?
●Connection.RollBackTrans方法:撤消/放棄一個事務。?
//啟動一個事務操作?
<%?Conn.BeginTrans?%>??
<%?sqlText="Insert?into?USER(userName,userPasswd)?values('"?%>?
<%?sqlText=sqlText?&?request("usrName")?&?"','"&request("usrPasswd")&"')?"?%>?
<%?conn.execute(sqlText)?%>?
<%?if?conn.Errors.Count>0?then?%>??
<%?conn.Errors.Clear?%>?
//如果插入數據操作失敗,則事務向前回滾?
<%?conn.RollBackTrans?%>??
<%?response.Redirct?RegisterFail.html?%>?
<%?end?if?%>?
<%?sqlText="Insert?into?USERDOC(userName,Age,Sex,PhoneNumber,Address)?"%>?
<%?sqlText=sqlText?&?"values('"&?request?("usrName")?&?"',?"?&?request("Age")?%>?
<%?sqlText=sqlText?&?",'"?&?request?("PhoneNum")?&?"','"?%>?
<%?sqlText=sqlText?&?request("Address")?&?"')?"?%>?
//執行事務單元中的第二條插入語句?
<%?conn.execute(sqlText)?%>??
<%?if?conn.Errors.Count>0?then?%>?
<%?conn.Errors.Clear?%>?
//如果操作失敗,則事務向前回滾?
<%?conn.RollBackTrans?%>??
<%?response.Redirct?RegisterFail.html?%>?
<%?end?if?%>?
//如果整個事務操作執行正確,則提交事務?
<%?Conn.CommitTrans?%>??
//轉向注冊成功處理頁面?
<%?response.Redirct?RegisterOk.html?%>??


方法二?
可以利用數據庫系統內部的事務處理機制,通過在數據庫服務器中編寫包含事務的存儲過程,完成對數據操作的事務處理。同時,利用ADO組件調用存儲過程,還可以根據存儲過程的返回代碼判斷事務處理是否執行成功。?

在數據庫系統中,每一條SQL語句都是一個事務。因此可以保證每條語句要么完成,要么退回到開始之處。但是如果希望一組SQL語句的操作要么全部完成,要么全部無效,就需要利用數據庫的事務處理機制來實現。?

在數據庫中生成存儲過程的主要代碼如下:?
Create?proc?RegisterUser?(@usrName?varchar(30),?@usrPasswd?varchar(30),@age?int,?@PhoneNum?varchar(20),?@Address?varchar(50)?)?as?begin?
//顯示定義并開始一個事務?
begin?tran??
insert?into?USER(userName,userPasswd)?values(@usrName,@usrPasswd)?
if?@@error<>0?
begin?
//操作失敗,則事務回滾?
rollback?tran??
//返回存儲過程,并設置返回碼為事務操作失敗?
return?-1??
end?
insert?into?USERDOC(userName,age,sex,PhoneNumber,Address)??
values(@Usrname,@age,@PhoneNum,@Address)?
if?@@error<>0?
begin?
//操作失敗,則事務回滾?
rollback?tran??
return?-1?
end?
//如果操作執行正確,則提交事務?
commit?tran??
return?0?
end?
在ASP腳本中調用數據庫存儲過程的主要代碼如下:?
<%?Set?Comm=server.CreateObject?
("ADODB.Command")?%>?
<%?Set?Comm.ActiveConnection=conn?%>?
<%?Comm.CommandType=adCmdStoredProc?%>?
<%?Comm.CommandText="RegisterUser"?%>?
//創建存儲過程返回參數對象?
<%?Set?RetCode=Comm.CreateParameter?
("RetCode",adInteger,adParamReturnValue)?%>??
//創建存儲過程輸入參數對象?
<%?Set?usrName=Comm.CreateParameter?("usrName",adVarchar,adParamInput,30)?%>??
<%?Set?usrPwd=Comm.CreateParameter?
("usrPasswd",adVarchar,adParamInput,30)?%>?
<%?Set?age=Comm.CreateParameter("age",adInteger,adParamInput)?%>?
<%?Set?PhoneNum=Comm.CreateParameter?
("PhoneNum",adVarchar,adParamInput,?20)?%>?
<%?Set?Address=Comm.CreateParameter("Address",adVarchar,adParamInput,50)?%>?
<%?Comm.Parameters.Append?usrName?%>?
<%?Comm.Parameters.Append?usrPwd?%>?
<%?Comm.Parameters.Append?age?%>?
<%?Comm.Parameters.Append?PhoneNum?%>?
<%?Comm.Parameters.Append?Address?%>?
<%?Comm.Parameters("usrName")=request("usrName")?%>?
<%?Comm.Parameters("usrPasswd")=request("usrPasswd")?%>?
<%?Comm.Parameters("age")=request("age")?%>?
<%?Comm.Parameters("PhoneNum")=request("PhoneNum")?%>?
<%?Comm.Parameters("Address")=request("Address")?%>?
<%?Comm.Execute?%>?
<%?RetValue=Cint(Comm("RetCode"))?%>?
//根據數據庫存儲過程返回代碼判斷注冊是否成功?
<%?if?RetValue<?0?then?%>??
<%?response.Redirect?RegisterFail.html?%>?
<%?else?%>?
<%?response.Redirect?RegisterOk.html?%>?
<%?end?if?%>?


方法三?
利用MTS(Microsoft?Transaction?Server)組件的事務處理機制實現事務處理時,需要特別注意的是,這種機制下的事務不能跨越多個ASP頁,如果一個事務處理需要來自多個組件的對象,則須將對這些對象的操作組合在一個ASP頁中。?

首先需要在頁首添加指令@TRANSACTION,將一個ASP頁面聲明為事務性。

@TRANSACTION指令必須在一頁中的第一行,否則將產生錯誤。當頁面中ASP腳本處理結束時,當前事務即告結束。?
<%@?TRANSACTION=Required?Language=?
VB?Script?%>?
//事務執行成功觸發事件?
<%?Sub?OnTransactionCommit()?%>??
<%?response.Redirect?RegisterOk.html?%>?
<%?End?Sub?%>?
//事物執行失敗觸發事件?
<%?Sub?OnTransactionAbort()?%>??
<%?response.Redirect?RegisterFail.html?%>?
<%?End?Sub?%>?
<%?sqlText="Insert?into?USER(userName,userPasswd)?values('"?%>?
<%?sqlText=sqlText?&?request("usrName")?&?"','"?&request("usrPasswd")&"')?"?%>?
<%?conn.execute(sqlText)?%>?
<%?if?conn.Errors.Count>0?then?%>?
<%?conn.Errors.Clear?%>?
<%?ObjectContext.SetAbort?%>?
<%?end?if?%>?
<%?sqlText="Insert?into?USERDOC(userName,Age,Sex,PhoneNumber,Address)?"%>?
<%?sqlText=sqlText?&?"values('"?&?request("usrName")&?"',?"?&?request("Age")?%>?
<%?sqlText=sqlText?&?",'"?&?request("PhoneNum")?&?"','"?%>?
<%?sqlText=sqlText?&?request("Address")?&?"')?"?%>?
<%?conn.execute(sqlText)?%>?
<%?if?conn.Errors.Count>0?then?%>?
<%?conn.Errors.Clear?%>?
<%?ObjectContext.SetAbort?%>?
<%?end?if?%>?
<%?ObjectContext.SetComplete?%>?


方案比較?
從靈活的角度考慮,選擇采用ASP數據庫組件的方法具有一定的優勢:既可以選用ADO數據庫組件完成事務處理,同時還可以根據實際需要,定制自己的數據庫組件(只要滿足ASP組件編寫規范即可)。如果從數據庫事務處理的可靠性等角度考慮,則采用數據庫內部的事務處理存儲過程更好。這樣可以直接利用數據庫事務機制完成應用程序的邏輯事務處理,安全可靠,并且減少了Web服務器與數據庫服務器之間的數據交互。這一點對分布式數據庫系統尤為重要。采用MTS組件的事務處理方法的優勢在于:由MTS服務器直接控制和管理組件(在MTS中注冊的組件)操作的完成和撤消,具有良好的擴展空間和應用前景,可以充分發揮MTS的技術優勢,增強網絡應用的容錯性能,提高IIS?Web服務器的動態性能。?

?本次錯新技術頻道小編給大家帶來的利用ASP實現事務處理的方法就到這里結束了,希望這篇文章可以幫助到大家。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品国产综合区久久久久久久| 亚洲人成网站在线播| 国产成人精品免费久久久久| 亚洲免费视频在线观看| 亚洲成人av在线播放| 91牛牛免费视频| 亚洲最大成人免费视频| 在线视频一区二区| 国产日产亚洲精品| 亚洲男人天堂手机在线| 亚洲国产高清福利视频| 国产精品成人免费视频| 国内精品视频在线| 日韩福利视频在线观看| 日韩欧美成人免费视频| 国产精品一区二区久久| 亚洲美女又黄又爽在线观看| 亚洲精品国产成人| 色香阁99久久精品久久久| 美日韩在线视频| 日韩欧美在线字幕| 国产区精品在线观看| 久久av红桃一区二区小说| 久久福利视频网| 欧美性猛交99久久久久99按摩| 日韩欧美在线字幕| 国产精品亚洲美女av网站| 日韩精品中文字幕在线播放| 国产精品色悠悠| 2019日本中文字幕| 日本亚洲欧美成人| 疯狂欧美牲乱大交777| 伊人亚洲福利一区二区三区| 亚洲欧洲av一区二区| 欧美精品第一页在线播放| 亚洲精品二三区| 久久免费视频在线| 色在人av网站天堂精品| 欧美性高潮在线| 国产视频亚洲精品| 欧美精品日韩www.p站| 日韩中文字幕在线观看| 欧美精品www| 亚洲国产成人91精品| 国产91精品视频在线观看| 91av视频导航| 国产精品国模在线| 亚洲国产精品一区二区三区| 国产精品狼人色视频一区| 欧美视频二区36p| 亚洲人成在线电影| 亚洲免费中文字幕| 亚洲天堂免费在线| 中文字幕在线观看亚洲| 国产一区二区黑人欧美xxxx| 亚洲欧美日韩精品久久奇米色影视| 91美女片黄在线观看游戏| 日本中文字幕不卡免费| 久久福利网址导航| 亚洲国产精久久久久久久| 日韩成人高清在线| 欧美午夜无遮挡| 亚洲人成伊人成综合网久久久| 亚洲无av在线中文字幕| 亚洲午夜女主播在线直播| 高跟丝袜一区二区三区| 久久精品久久久久电影| 日本老师69xxx| 成人日韩在线电影| 国产精品久久久久久久久久免费| 久久久精品免费视频| 美女国内精品自产拍在线播放| 国产精品永久免费| 国产精品视频专区| 亚洲一区二区三区四区在线播放| 九九精品在线视频| 欧美亚洲视频在线看网址| 国产精品999| 国产精品欧美激情在线播放| 91精品国产777在线观看| 91精品国产91久久久久久久久| 伊人久久免费视频| 欧美日韩国产一区中文午夜| 欧美日韩免费区域视频在线观看| 欧美一级免费看| 91精品久久久久久久久久另类| 日韩欧美在线看| 亚洲国产精品久久久| 成人黄色生活片| 日韩成人黄色av| 91亚洲一区精品| 91在线观看免费观看| 欧洲日韩成人av| 国产91av在线| 国产亚洲美女久久| 国产精品成人v| 成人免费在线视频网址| 欧美贵妇videos办公室| 欧美一区二区三区图| 中文字幕免费精品一区| 欧美日韩免费网站| 色婷婷av一区二区三区久久| 成人精品视频在线| 亚洲欧美激情精品一区二区| 午夜精品www| 日韩极品精品视频免费观看| 亚洲人成网站999久久久综合| 欧美成人免费视频| 永久免费精品影视网站| 91国产在线精品| 国产日韩精品在线播放| 91在线视频一区| 亚洲成人av在线| 日韩欧美在线一区| 亚洲v日韩v综合v精品v| 欧美日韩另类视频| 欧美天堂在线观看| 欧美成人精品影院| 久久精品国产亚洲| 这里精品视频免费| 国产一区二区三区网站| 久久精品国产69国产精品亚洲| 国产精品wwww| 国产精品久久久久久久久影视| 91九色国产在线| 欧美成人精品一区| 91免费电影网站| 日本精品va在线观看| 91免费观看网站| 亚洲欧美国产一本综合首页| 欧美精品在线极品| 中文字幕日韩高清| 中文字幕亚洲一区二区三区| 久久久av免费| 国产一区二区三区日韩欧美| 日韩在线播放视频| 国产午夜精品一区二区三区| 亚洲综合一区二区不卡| 亚洲国产精久久久久久久| 国产精品盗摄久久久| 国产亚洲欧美视频| 日韩中文字幕在线免费观看| 国产精品自拍网| 欧美亚洲一区在线| 中文字幕在线看视频国产欧美在线看完整| 亚州av一区二区| 国产欧美一区二区三区四区| 亚洲一区二区中文字幕| 久久久久久免费精品| 欧美肥婆姓交大片| 一道本无吗dⅴd在线播放一区| 国产精品美女网站| 日韩美女视频免费看| 成人中文字幕+乱码+中文字幕| 亚洲图片在线综合| 欧美又大粗又爽又黄大片视频| 91精品视频在线免费观看| 最近日韩中文字幕中文| 欧美一乱一性一交一视频| 91精品国产91久久久久久最新| 国产91免费观看| 中文综合在线观看| 人体精品一二三区| 欧美成年人视频|