全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:2710
推到 Plurk!
推到 Facebook!

MS-SQL Store Procedure 一問

尚未結案
SuperLowB
初階會員


發表:96
回覆:77
積分:34
註冊:2003-06-11

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-12-30 15:10:13 IP:210.177.xxx.xxx 未訂閱
我用的是MSSQL7.0  請問我有一個store procedure 
1. CREATE PROCEDURE [dbo].[spUpdUser](@UserID INT,@Pwd varchar(10)) AS
2. BEGIN  
3.     Declare @keyID int
4.   BEGIN TRAN
5.     update tbMyUser set password=@Pwd where @UserID
6.    
7.     update tbkeyCount set cnt=cnt  1 where CntName='UserlogID'
8.     Select @keyID=cnt from tbkeyCount where CntName='UserlogID'
9.     
10.    insert into tbUserlog (UserlogID,LogDesc) values (@keyID,'Test')
11.    
12.     IF @@ERROR=0 
13.       COMMIT TRAN      
14.     ELSE
15.       ROLLBACK TRAN
16.END
17.GO
問題: 我想在line 7 的update statement 立即update這個field的值,而不想當有@@error出現時就rollback line 7 的update statement.即是話即使 line 7 的update statement包在Begin tran裏,但也不受rollback影響,update 了就是update 了,可以嗎? 註: 我不可以把這個update statement 調出begin tran外 發表人 - superlowb 於 2003/12/30 15:16:50
timhuang
尊榮會員


發表:78
回覆:1815
積分:1608
註冊:2002-07-15

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-12-30 18:15:39 IP:203.95.xxx.xxx 未訂閱
Hi, 拉出 begin tran 段!    
1. CREATE PROCEDURE [dbo].[spUpdUser](@UserID INT,@Pwd varchar(10)) AS
2. BEGIN  
3.     Declare @keyID int
       update tbkeyCount set cnt=cnt +1 where CntName='UserlogID'
4.   BEGIN TRAN
5.     update tbMyUser set password=@Pwd where @UserID
6.    
7.     update tbkeyCount set cnt=cnt +1 where CntName='UserlogID'
8.     Select @keyID=cnt from tbkeyCount where CntName='UserlogID'
9.     
10.    insert into tbUserlog (UserlogID,LogDesc) values (@keyID,'Test')
11.    
12.     IF @@ERROR=0 
13.       COMMIT TRAN      
14.     ELSE
15.       ROLLBACK TRAN
16.END
17.GO
Mickey
版主


發表:77
回覆:1882
積分:1390
註冊:2002-12-11

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-12-31 08:23:42 IP:218.163.xxx.xxx 未訂閱
SuperLowB 你好:    節錄一段 MSSQL 線上說明, 參考看看:

巢狀交易
外顯交易 (Explicit Transaction) 可以是巢狀的。其主要目的是要支援預存程序 (Stored Procedure) 中的交易,讓交易可以被已經在交易中的處理序呼叫,或沒有動作的交易內的處理序呼叫。    下列範例顯示巢狀交易的使用意圖。程序 TransProc 強制交易,而不論執行此程序之處理序的交易模式為何。如果是在交易作用時呼叫 TransProc,位於 TransProc 的巢狀交易大部分會被忽略,並且依照外部交易最後執行的動作,來認可或復原其中的 INSERT 陳述式。如果執行 TransProc 的處理序沒有尚未處理的交易,程序結尾的 COMMIT TRANSACTION 便有效地認可 INSERT 陳述式。    SET QUOTED_IDENTIFIER OFF
GO
SET NOCOUNT OFF
GO
USE pubs
GO
CREATE TABLE TestTrans(Cola INT PRIMARY KEY,
               Colb CHAR(3) NOT NULL)
GO
CREATE PROCEDURE TransProc @PriKey INT, @CharCol CHAR(3) AS
BEGIN TRANSACTION InProc
INSERT INTO TestTrans VALUES (@PriKey, @CharCol)
INSERT INTO TestTrans VALUES (@PriKey   1, @CharCol)
COMMIT TRANSACTION InProc
GO
/* Start a transaction and execute TransProc */
BEGIN TRANSACTION OutOfProc
GO
EXEC TransProc 1, 'aaa'
GO
/* Roll back the outer transaction, this will
   roll back TransProc's nested transaction */
ROLLBACK TRANSACTION OutOfProc
GO
EXECUTE TransProc 3,'bbb'
GO
/* The following SELECT statement shows only rows 3 and 4 are 
   still in the table. This indicates that the commit
   of the inner transaction from the first EXECUTE statement of
   TransProc was overridden by the subsequent rollback. */
SELECT * FROM TestTrans
GO    
系統時間:2024-11-23 6:33:51
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!