婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 利用ASP實現事務處理的方法

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

熱門標簽:辦理400電話一年多少錢 咸陽銷售外呼系統 為什么外呼系統需要預存話費呢 外呼回撥系統圖片 蘭州智能語音電銷機器人功能 企數外呼系統能用多久 寧夏怎么申請400電話 常用地圖標注范圍點 離線電子地圖標注軟件注冊
 利用ASP實現事務處理的方法     選擇自 AppleBBS 的 Blog  
關鍵字   利用ASP實現事務處理的方法 
出處    

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

實際上,在默認方式下對數據庫的每一次操作都是隱含的事務處理。本文以一個典型的用戶注冊程序為例,介紹三種利用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實現事務處理的方法》,本文關鍵詞  利用,ASP,實現,事務處理,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《利用ASP實現事務處理的方法》相關的同類信息!
  • 本頁收集關于利用ASP實現事務處理的方法的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    日韩欧美电影一二三| 欧美一级一区二区| 欧美丝袜丝交足nylons图片| 亚洲国产精品成人综合色在线婷婷| 偷拍与自拍一区| 欧美欧美欧美欧美首页| 视频精品一区二区| 欧美自拍偷拍午夜视频| 亚洲成人午夜电影| 日韩免费视频一区| 国产一区二区三区最好精华液 | 激情欧美一区二区| 欧美xxxxx裸体时装秀| 久久97超碰色| 国产精品毛片久久久久久久| 日本精品一区二区三区四区的功能| 亚洲电影第三页| 日韩午夜在线影院| 不卡大黄网站免费看| 亚洲二区视频在线| 亚洲精品在线免费播放| 99国产欧美久久久精品| 亚洲不卡av一区二区三区| 精品嫩草影院久久| 91久久久免费一区二区| 美女视频黄 久久| 亚洲乱码国产乱码精品精小说| 欧美一区二区三区在线观看视频| 国产精品1区2区3区在线观看| 亚洲男人天堂一区| 精品国产乱码久久久久久久久| 国产91精品免费| 美腿丝袜在线亚洲一区| 一区二区三区四区av| 国产网站一区二区三区| 欧美一区二区在线视频| 99久久综合狠狠综合久久| 免费高清视频精品| 亚洲综合一区二区精品导航| 国产偷v国产偷v亚洲高清| 日韩一区二区免费电影| jlzzjlzz欧美大全| 国产精品一二三在| 蜜桃在线一区二区三区| 亚洲综合男人的天堂| 国产精品人人做人人爽人人添| 日韩精品在线网站| 日韩一区二区免费电影| 欧美日韩国产一级片| 色婷婷综合五月| 菠萝蜜视频在线观看一区| 国产在线看一区| 精久久久久久久久久久| 青娱乐精品视频在线| 午夜国产精品一区| 亚洲一二三区视频在线观看| 亚洲人成伊人成综合网小说| 国产日韩av一区二区| 久久久精品欧美丰满| 精品va天堂亚洲国产| 欧美一级国产精品| 欧美一区二区视频在线观看 | 色哟哟在线观看一区二区三区| 国产一区 二区 三区一级| 美女视频黄免费的久久| 激情都市一区二区| 国产在线精品免费| 国产成人欧美日韩在线电影| 精品伊人久久久久7777人| 蜜桃av一区二区三区电影| 丝袜亚洲精品中文字幕一区| 三级影片在线观看欧美日韩一区二区| 亚洲 欧美综合在线网络| 奇米影视在线99精品| 老汉av免费一区二区三区| 久久精品国产一区二区三| 精品一区中文字幕| 成人av网站在线观看免费| 91免费视频网| 欧美撒尿777hd撒尿| 欧美一级二级三级乱码| 日韩精品中午字幕| 国产精品天美传媒沈樵| 亚洲三级久久久| 偷拍自拍另类欧美| 国产成人亚洲综合a∨猫咪| 成人免费毛片aaaaa**| 色8久久精品久久久久久蜜| 欧美绝品在线观看成人午夜影视| 制服丝袜日韩国产| 国产精品欧美一级免费| 亚洲一区电影777| 欧美aⅴ一区二区三区视频| 国产精品一区二区在线观看网站| 不卡区在线中文字幕| 欧美久久久久久久久中文字幕| 久久婷婷一区二区三区| 一区二区激情视频| 国产精品综合视频| 欧美日韩亚洲综合一区| 国产精品网友自拍| 免费视频最近日韩| 99精品久久99久久久久| 久久综合九色综合97_久久久| 一区二区三区免费在线观看| 国产精品综合久久| 91精品国产综合久久久久| 一区在线中文字幕| 久久99国产精品久久99果冻传媒| 91激情在线视频| 国产精品国产馆在线真实露脸| 蜜桃av噜噜一区| 欧美日韩精品福利| 亚洲日本青草视频在线怡红院| 日本女人一区二区三区| 99视频国产精品| 欧美电影免费观看高清完整版在| 亚洲精品videosex极品| 国产精品一区二区久激情瑜伽| 欧美性色黄大片| 国产精品国产三级国产普通话99 | 欧美精品自拍偷拍动漫精品| 日本一区二区动态图| 极品少妇xxxx精品少妇偷拍| 欧美性大战久久| 亚洲欧洲日韩在线| 国产精品综合在线视频| 欧美一区二区三区四区五区 | 久久久久久久综合| 亚洲一区二区四区蜜桃| 粗大黑人巨茎大战欧美成人| 精品电影一区二区三区| 亚洲一二三区在线观看| 一本久久综合亚洲鲁鲁五月天| 国产女主播在线一区二区| 国产一区二区三区四区五区美女| 在线看日韩精品电影| 亚洲一级片在线观看| 欧美日韩一区二区在线观看 | 国产精品系列在线观看| 久久一区二区三区国产精品| 麻豆成人在线观看| 午夜精品久久久| 欧美一区二区在线看| 免费看精品久久片| 日韩欧美黄色影院| 日本午夜一区二区| 欧美美女网站色| 久久精品国产一区二区| 国产亚洲人成网站| 99精品视频在线观看| 亚洲色图第一区| 欧美日韩一区二区在线观看| 青青草国产成人av片免费| 26uuu亚洲综合色欧美| 成人免费三级在线| 一区二区三区不卡视频| 欧美老人xxxx18| 男女视频一区二区| 亚洲精品一区二区三区影院| 国产乱码精品一区二区三区av | 日本久久精品电影| 亚洲成人福利片| 欧美精品777| 国产麻豆视频精品| 最新日韩av在线| 91麻豆精品国产91久久久资源速度 | 中文字幕中文字幕一区二区| 99久久亚洲一区二区三区青草| 亚洲卡通动漫在线| 日韩亚洲欧美高清| 色婷婷av一区二区三区软件| 人禽交欧美网站| 国产精品久久福利| 日韩精品一区二区在线观看| 成人av综合在线| 日本不卡一区二区三区高清视频| 欧美xxx久久| 99久久国产综合精品麻豆| 日韩一本二本av| 99久久久无码国产精品| 美国三级日本三级久久99| 国产精品卡一卡二卡三| 欧美亚洲国产一卡| 东方aⅴ免费观看久久av| 亚洲欧美区自拍先锋| 久久久www免费人成精品| 91福利资源站| 国产成人精品三级| 日本亚洲免费观看| 国产精品久久久久久久久晋中 | 亚洲乱码国产乱码精品精98午夜 | 精品国产乱子伦一区| 欧美日韩亚洲国产综合| 91网站最新网址| 国产成人精品影视| 国产伦理精品不卡| 日韩精品欧美精品| 一区二区高清视频在线观看| 国产精品久久国产精麻豆99网站|