国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > ASP > 正文

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

2024-05-04 11:01:42
字體:
來源:轉載
供稿:網友
 利用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 %>  
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 射洪县| 镇巴县| 古丈县| 沾益县| 马关县| 呼和浩特市| 宜宾县| 色达县| 黄平县| 客服| 临高县| 旬邑县| 武功县| 浦北县| 阿瓦提县| 沾化县| 通海县| 五河县| 海宁市| 台中县| 广东省| 龙口市| 泉州市| 梓潼县| 文昌市| 浦城县| 烟台市| 会昌县| 信阳市| 璧山县| 阜康市| 吴忠市| 沙田区| 金华市| 文水县| 阜平县| 忻州市| 新乐市| 民乐县| 金坛市| 高唐县|