0BEGINprint'1'R" />

欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

事務——sql server中的事務應用舉例

系統 1902 0

?sql中事務只針對一個update,delete,insert語句,如果一段程序中有超過一個這樣的語句,就需要每個都判斷是否出錯,否則就會出現若干我們不希望的情形出現,舉例如下(表結構見最后):

????????? 1,有三個 insert語句(or其它語句),第一個出錯,第二個對了,第三個錯了,如下:
BEGIN
BEGIN TRANSACTION

?????? print 'bb'
?????? insert into testNewID (a) values('aa')
?????? IF @@error <> 0
?????? BEGIN
?????????????? print '1'
????? ROLLBACK TRANSACTION
?????????????? return
?????? END

??
--????? select * from dd
?????? insert into testNewID(id,a) values(2,'bb')
?????? IF @@error <> 0
?????? BEGIN
?????????????? print '2'
????? ROLLBACK TRANSACTION
?????????????? return
?????? END

????? insert into testnewid(a) values('cc')

IF @@error <> 0
???? BEGIN
?????????????? print '3'
????? ROLLBACK TRANSACTION
?????????????? return
???? END

BEGIN
?????????????? print 'finished'
???????? COMMIT TRANSACTION
END

??
SET NOCOUNT OFF
END

--
--delete from testnewid
--select * from testNewID

這樣寫就沒問題,因為每個insert語句都經過了判斷,一旦出錯,回滾整個事務。如果這樣寫:

???????????????????? 2,

BEGIN
BEGIN TRANSACTION

?????? print 'bb'
?????? insert into testNewID (a) values('aa')
?????? insert into testNewID(id,a) values(2,'bb')

????? insert into testnewid(a) values('cc')

IF @@error <> 0
???? BEGIN
?????????????? print '3'
????? ROLLBACK TRANSACTION
?????????????? return
???? END

BEGIN
?????????????? print 'finished'
???????? COMMIT TRANSACTION
END

??
SET NOCOUNT OFF
END

--
--delete from testnewid
--select * from testNewID

這樣的話@@error只收到最后一個insert語句的信息,它是對的,所以@@error的值是0,沒錯,所以不回滾,commit語句執行,第一個插入成功,第二個失敗,第三個成功,沒有起到事務的作用。

?

???????????? 另外,如果程序中除了insert,update,delete之外的語句出現錯誤,那么整個程序停止,和事務沒有關系。事務只針對insert,update,delete這三種操作。

附:用到的表結構???? testnewid(id,a),id自增

以上是我自己的一點小經驗,可能有不對和不完善的地方,哪位看到了請千萬指出來,萬分感謝。????????????

今天得到tony的指點,原來這個事務可以優化一下,變得簡單:

Begin TRANSACTION
????????? DECLARE @Err?????????? int
????????? SET?????? @Err = 0

--在每一個操作語句之后(包括select等除update,insert,delete之外的語句)判斷一下@@error

?????? IF @@error <> 0
?????? Set @Err = @@Error

--如果以上的操作中有一個有問題,那么@Err肯定不是零了。就 rollback,如果是零說明沒有出錯的,

--就commit

??? IF @Err <> 0
???? BEGIN
????? ROLLBACK TRANSACTION?????????
???? END
??? ELSE
???? BEGIN
????? COMMIT TRANSACTION
???? END

事務——sql server中的事務應用舉例


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 国产一卡二卡三卡 | 亚洲国产午夜精品乱码 | 一级毛片一级毛片一级毛片 | 久久中文字幕美谷朱里 | 日日夜夜免费精品视频 | 日本一区二区三区精品国产 | 久综合网| 色综合久久天天综合网 | 欧美色伊人| av中文字幕在线 | 欧美无乱码久久久免费午夜一区 | 五月婷六月丁香狠狠躁狠狠爱 | 日韩电影一区二区三区 | A片扒开双腿进入做视频 | 小视频在线观看免费 | 亚洲欧美不卡 | 羞羞的网址| 视频在线观看一区 | a黄视频 | 黄色免费网页 | 色在线观看视频 | 久热免费在线视频 | 91精品国产一区二区 | 国产成人免费永久播放视频平台 | 亚洲经典在线中文字幕 | 欧美一级高潮片免费的 | 欧美日本免费 | 中文字幕a∨在线乱码免费看 | 欧美高清在线精品一区二区不卡 | 日韩国产第一页 | 欧美日韩中文字幕在线 | 傲视影院午夜毛片 | 视频在线一区二区 | 性夜影院爽黄A爽免费动漫 日韩精品在线一区二区 | 99re6热只有精品免费观看 | 欧洲一级毛片 | 国产一区二区三区久久久久久久久 | 欧美激情精品久久久久久久 | 狠狠影院 | 性色网站 | 激情五月婷婷综合 |