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

主頁(yè) > 知識(shí)庫(kù) > 利用ASP實(shí)現(xiàn)事務(wù)處理的方法

利用ASP實(shí)現(xiàn)事務(wù)處理的方法

熱門(mén)標(biāo)簽:辦理400電話一年多少錢(qián) 咸陽(yáng)銷售外呼系統(tǒng) 為什么外呼系統(tǒng)需要預(yù)存話費(fèi)呢 外呼回?fù)芟到y(tǒng)圖片 蘭州智能語(yǔ)音電銷機(jī)器人功能 企數(shù)外呼系統(tǒng)能用多久 寧夏怎么申請(qǐng)400電話 常用地圖標(biāo)注范圍點(diǎn) 離線電子地圖標(biāo)注軟件注冊(cè)
 利用ASP實(shí)現(xiàn)事務(wù)處理的方法     選擇自 AppleBBS 的 Blog  
關(guān)鍵字   利用ASP實(shí)現(xiàn)事務(wù)處理的方法 
出處    

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

實(shí)際上,在默認(rèn)方式下對(duì)數(shù)據(jù)庫(kù)的每一次操作都是隱含的事務(wù)處理。本文以一個(gè)典型的用戶注冊(cè)程序?yàn)槔榻B三種利用ASP實(shí)現(xiàn)事務(wù)處理的方法:基于ASP數(shù)據(jù)庫(kù)組件的解決方法、基于數(shù)據(jù)庫(kù)內(nèi)部的事務(wù)處理機(jī)制的解決方法和基于MTS組件的解決方法。 

程序功能 
在SQL Server數(shù)據(jù)庫(kù)中建立兩個(gè)表:USER表和USERDOC表。其中USER表中存放的是注冊(cè)用戶的用戶名和密碼,USERDOC表中存放的是該注冊(cè)用戶的個(gè)人資料,并且以用戶名為索引。下面是表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)) 

當(dāng)用戶請(qǐng)求注冊(cè)時(shí),ASP腳本先將用戶名和密碼插入到USER表中,然后在USERDOC表中插入用戶個(gè)人信息(年齡、性別、聯(lián)系電話和家庭住址等)。同時(shí),應(yīng)用程序還必須保證USER表中的每一條記錄在USERDOC表中都有相應(yīng)的記錄。 

方法一 
利用ASP內(nèi)置ADO組件中的Connection對(duì)象可以實(shí)現(xiàn)對(duì)數(shù)據(jù)庫(kù)操作的事務(wù)性處理。Connection對(duì)象的部分方法如下: 
●Connection.BeginTrans方法:?jiǎn)?dòng)一個(gè)事務(wù); 
●Connection.CommitTrans方法:完成/提交一個(gè)事務(wù); 
●Connection.RollBackTrans方法:撤消/放棄一個(gè)事務(wù)。 
//啟動(dòng)一個(gè)事務(wù)操作 
% 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 %> 
//如果插入數(shù)據(jù)操作失敗,則事務(wù)向前回滾 
% 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")  "') " %> 
//執(zhí)行事務(wù)單元中的第二條插入語(yǔ)句 
% conn.execute(sqlText) %>  
% if conn.Errors.Count>0 then %> 
% conn.Errors.Clear %> 
//如果操作失敗,則事務(wù)向前回滾 
% conn.RollBackTrans %>  
% response.Redirct RegisterFail.html %> 
% end if %> 
//如果整個(gè)事務(wù)操作執(zhí)行正確,則提交事務(wù) 
% Conn.CommitTrans %>  
//轉(zhuǎn)向注冊(cè)成功處理頁(yè)面 
% response.Redirct RegisterOk.html %>  


方法二 
可以利用數(shù)據(jù)庫(kù)系統(tǒng)內(nèi)部的事務(wù)處理機(jī)制,通過(guò)在數(shù)據(jù)庫(kù)服務(wù)器中編寫(xiě)包含事務(wù)的存儲(chǔ)過(guò)程,完成對(duì)數(shù)據(jù)操作的事務(wù)處理。同時(shí),利用ADO組件調(diào)用存儲(chǔ)過(guò)程,還可以根據(jù)存儲(chǔ)過(guò)程的返回代碼判斷事務(wù)處理是否執(zhí)行成功。 

在數(shù)據(jù)庫(kù)系統(tǒng)中,每一條SQL語(yǔ)句都是一個(gè)事務(wù)。因此可以保證每條語(yǔ)句要么完成,要么退回到開(kāi)始之處。但是如果希望一組SQL語(yǔ)句的操作要么全部完成,要么全部無(wú)效,就需要利用數(shù)據(jù)庫(kù)的事務(wù)處理機(jī)制來(lái)實(shí)現(xiàn)。 

在數(shù)據(jù)庫(kù)中生成存儲(chǔ)過(guò)程的主要代碼如下: 
Create proc RegisterUser (@usrName varchar(30), @usrPasswd varchar(30),@age int, @PhoneNum varchar(20), @Address varchar(50) ) as begin 
//顯示定義并開(kāi)始一個(gè)事務(wù) 
begin tran  
insert into USER(userName,userPasswd) values(@usrName,@usrPasswd) 
if @@error>0 
begin 
//操作失敗,則事務(wù)回滾 
rollback tran  
//返回存儲(chǔ)過(guò)程,并設(shè)置返回碼為事務(wù)操作失敗 
return -1  
end 
insert into USERDOC(userName,age,sex,PhoneNumber,Address)  
values(@Usrname,@age,@PhoneNum,@Address) 
if @@error>0 
begin 
//操作失敗,則事務(wù)回滾 
rollback tran  
return -1 
end 
//如果操作執(zhí)行正確,則提交事務(wù) 
commit tran  
return 0 
end 
在ASP腳本中調(diào)用數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程的主要代碼如下: 
% Set Comm=server.CreateObject 
("ADODB.Command") %> 
% Set Comm.ActiveConnection=conn %> 
% Comm.CommandType=adCmdStoredProc %> 
% Comm.CommandText="RegisterUser" %> 
//創(chuàng)建存儲(chǔ)過(guò)程返回參數(shù)對(duì)象 
% Set RetCode=Comm.CreateParameter 
("RetCode",adInteger,adParamReturnValue) %>  
//創(chuàng)建存儲(chǔ)過(guò)程輸入?yún)?shù)對(duì)象 
% 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")) %> 
//根據(jù)數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程返回代碼判斷注冊(cè)是否成功 
% if RetValue 0 then %>  
% response.Redirect RegisterFail.html %> 
% else %> 
% response.Redirect RegisterOk.html %> 
% end if %> 


方法三 
利用MTS(Microsoft Transaction Server)組件的事務(wù)處理機(jī)制實(shí)現(xiàn)事務(wù)處理時(shí),需要特別注意的是,這種機(jī)制下的事務(wù)不能跨越多個(gè)ASP頁(yè),如果一個(gè)事務(wù)處理需要來(lái)自多個(gè)組件的對(duì)象,則須將對(duì)這些對(duì)象的操作組合在一個(gè)ASP頁(yè)中。 

首先需要在頁(yè)首添加指令@TRANSACTION,將一個(gè)ASP頁(yè)面聲明為事務(wù)性。

@TRANSACTION指令必須在一頁(yè)中的第一行,否則將產(chǎn)生錯(cuò)誤。當(dāng)頁(yè)面中ASP腳本處理結(jié)束時(shí),當(dāng)前事務(wù)即告結(jié)束。 
%@ TRANSACTION=Required Language= 
VB Script %> 
//事務(wù)執(zhí)行成功觸發(fā)事件 
% Sub OnTransactionCommit() %>  
% response.Redirect RegisterOk.html %> 
% End Sub %> 
//事物執(zhí)行失敗觸發(fā)事件 
% 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數(shù)據(jù)庫(kù)組件的方法具有一定的優(yōu)勢(shì):既可以選用ADO數(shù)據(jù)庫(kù)組件完成事務(wù)處理,同時(shí)還可以根據(jù)實(shí)際需要,定制自己的數(shù)據(jù)庫(kù)組件(只要滿足ASP組件編寫(xiě)規(guī)范即可)。如果從數(shù)據(jù)庫(kù)事務(wù)處理的可靠性等角度考慮,則采用數(shù)據(jù)庫(kù)內(nèi)部的事務(wù)處理存儲(chǔ)過(guò)程更好。這樣可以直接利用數(shù)據(jù)庫(kù)事務(wù)機(jī)制完成應(yīng)用程序的邏輯事務(wù)處理,安全可靠,并且減少了Web服務(wù)器與數(shù)據(jù)庫(kù)服務(wù)器之間的數(shù)據(jù)交互。這一點(diǎn)對(duì)分布式數(shù)據(jù)庫(kù)系統(tǒng)尤為重要。采用MTS組件的事務(wù)處理方法的優(yōu)勢(shì)在于:由MTS服務(wù)器直接控制和管理組件(在MTS中注冊(cè)的組件)操作的完成和撤消,具有良好的擴(kuò)展空間和應(yīng)用前景,可以充分發(fā)揮MTS的技術(shù)優(yōu)勢(shì),增強(qiáng)網(wǎng)絡(luò)應(yīng)用的容錯(cuò)性能,提高IIS Web服務(wù)器的動(dòng)態(tài)性能。 

 

標(biāo)簽:麗江 溫州 鐵嶺 泰州 昌都 家電維修 昆明 咸陽(yáng)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《利用ASP實(shí)現(xiàn)事務(wù)處理的方法》,本文關(guān)鍵詞  利用,ASP,實(shí)現(xiàn),事務(wù)處理,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《利用ASP實(shí)現(xiàn)事務(wù)處理的方法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于利用ASP實(shí)現(xiàn)事務(wù)處理的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    久久久激情视频| aaa欧美日韩| 国产精品卡一卡二卡三| 一本大道综合伊人精品热热| 免费在线看一区| 国产精品久久久爽爽爽麻豆色哟哟| 在线观看日韩电影| 成人性视频免费网站| 性久久久久久久久久久久 | 精品国产一区二区精华| 成人毛片老司机大片| 五月综合激情婷婷六月色窝| 中文字幕精品一区| 精品少妇一区二区三区免费观看| 色先锋久久av资源部| 国产风韵犹存在线视精品| 日韩—二三区免费观看av| 亚洲视频每日更新| 欧美激情在线看| 欧美不卡一区二区| 69堂亚洲精品首页| 91福利社在线观看| 91免费看`日韩一区二区| 国产大陆精品国产| 精品伊人久久久久7777人| 午夜伦欧美伦电影理论片| 亚洲精品免费电影| 亚洲免费观看视频| 国产精品每日更新在线播放网址| www一区二区| 欧美tickle裸体挠脚心vk| 日韩欧美一级在线播放| 在线播放欧美女士性生活| 91福利小视频| 在线观看亚洲a| 欧美综合在线视频| 在线观看中文字幕不卡| 一本久道久久综合中文字幕| 成人性生交大片免费看中文网站| 国产精品综合视频| 国产成人精品一区二区三区四区 | 99视频在线精品| gogo大胆日本视频一区| 99视频精品全部免费在线| 成人av网站免费| 成人av第一页| 91蜜桃在线免费视频| 91捆绑美女网站| 欧美在线播放高清精品| 在线观看成人小视频| 欧美在线免费播放| 91精品国产欧美日韩| 欧美一区二区三区在线视频| 91精品国产乱码| 精品久久一二三区| 国产精品人人做人人爽人人添| 国产精品无遮挡| 亚洲欧美日韩国产综合在线| 亚洲综合激情另类小说区| 午夜精品国产更新| 麻豆成人免费电影| 丁香婷婷综合色啪| 91成人在线免费观看| 欧美日韩免费一区二区三区| 欧美一区二区三区在线电影| 日韩精品一区二区三区swag | 天天操天天综合网| 韩国精品久久久| www.日韩大片| 欧美理论电影在线| 国产亚洲成年网址在线观看| 综合久久久久久| 日韩**一区毛片| 国产精品香蕉一区二区三区| 91视频精品在这里| 欧美日韩视频在线观看一区二区三区| 欧美电影免费观看高清完整版在线| 国产无人区一区二区三区| 亚洲精品国产视频| 日本va欧美va欧美va精品| 国产精品综合网| 欧美亚洲另类激情小说| 欧美精品一区二区高清在线观看| 综合欧美亚洲日本| 裸体一区二区三区| 97精品久久久久中文字幕 | 久久久久久综合| 亚洲国产精品一区二区www| 久久99国产精品久久| 一本久道中文字幕精品亚洲嫩| 日韩一区二区三区av| 日本一区二区三区四区| 日本亚洲最大的色成网站www| 国产成人精品www牛牛影视| 欧美日韩精品三区| 国产精品国产三级国产普通话99| 午夜国产精品一区| 99久久99久久精品免费观看| 欧美本精品男人aⅴ天堂| 一区二区不卡在线视频 午夜欧美不卡在 | 一区二区三区四区亚洲| 狠狠色综合色综合网络| 欧美视频三区在线播放| 日本一区二区电影| 日韩电影在线免费| 欧美亚一区二区| 中文字幕亚洲在| 国产一区二区h| 欧美一区二区三区系列电影| 日韩理论片网站| 国产老妇另类xxxxx| 制服丝袜中文字幕一区| 一卡二卡欧美日韩| 不卡的看片网站| 欧美激情艳妇裸体舞| 狠狠色狠狠色合久久伊人| 欧美一区二区三区在线视频| 亚洲综合精品自拍| 91麻豆高清视频| 亚洲四区在线观看| av在线播放一区二区三区| 日本一区二区三区高清不卡| 乱中年女人伦av一区二区| 91精品国产91综合久久蜜臀| 亚洲午夜影视影院在线观看| 91免费观看国产| 亚洲三级视频在线观看| 91亚洲精品久久久蜜桃网站| 国产日产欧美一区| 久久草av在线| 日韩精品最新网址| 久久精品国产在热久久| 日韩女优视频免费观看| 日韩av在线播放中文字幕| 91精品国产综合久久小美女| 香蕉成人啪国产精品视频综合网| 在线观看亚洲成人| 亚洲成人精品一区二区| 欧美伊人久久久久久午夜久久久久| 亚洲精品伦理在线| 欧美亚洲动漫制服丝袜| 五月天激情综合网| 欧美日本一区二区| 日韩中文字幕麻豆| 欧美一区二区三区免费视频| 日韩经典中文字幕一区| 欧美一三区三区四区免费在线看 | 欧美精品一二三| 国产91在线观看丝袜| 精品久久久久久久久久久久包黑料 | 92精品国产成人观看免费| 国产精品女同互慰在线看| 高清av一区二区| 日韩美女啊v在线免费观看| 91捆绑美女网站| 午夜视黄欧洲亚洲| 日韩一级在线观看| 国内精品伊人久久久久av一坑| 26uuu国产电影一区二区| 国产精品18久久久久久久久 | 久久精品国产一区二区三区免费看| 欧美成人精品福利| 国产精品国产三级国产| 日本精品视频一区二区三区| 一区二区三区在线视频免费 | 中文字幕av资源一区| 91免费观看在线| 日韩电影在线一区二区三区| 欧美mv日韩mv| 懂色一区二区三区免费观看| 亚洲伦理在线精品| 日韩欧美激情在线| 成人网在线播放| 性做久久久久久久久| 久久久久国色av免费看影院| 91啪在线观看| 免费人成精品欧美精品| 亚洲国产成人私人影院tom| 欧美日韩一区二区在线观看| 国产一区高清在线| 亚洲成人一二三| 久久精品亚洲精品国产欧美kt∨| 91在线无精精品入口| 日本中文字幕不卡| 中文在线资源观看网站视频免费不卡| 欧美日韩精品一区二区三区四区| 国产高清不卡一区二区| 一区二区三区丝袜| 国产日本欧洲亚洲| 欧美一区二区三区免费视频| 粉嫩蜜臀av国产精品网站| 亚洲成av人影院| 中文字幕乱码久久午夜不卡| 5月丁香婷婷综合| 91免费视频大全| 国产成人综合精品三级| 午夜精品在线看| 一区二区三区在线播放| 国产亚洲人成网站| 日韩情涩欧美日韩视频|