电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

在SQL Server 2005中解決死鎖

瀏覽:163日期:2023-10-30 09:42:25

數據庫操作的死鎖是不可避免的,本文并不打算討論死鎖如何產生,重點在于解決死鎖,通過SQL Server 2005, 現在似乎有了一種新的解決辦法。

將下面的SQL語句放在兩個不同的連接里面,并且在5秒內同時執行,將會發生死鎖。

use Northwind

begin tran insert into Orders(CustomerId) values('ALFKI') waitfor delay '00:00:05' select * from Orders where CustomerId = 'ALFKI' commit print 'end tran' SQL Server對付死鎖的辦法是犧牲掉其中的一個,拋出異常,并且回滾事務。在SQL Server 2000,語句一旦發生異常,T-SQL將不會繼續運行,上面被犧牲的連接中, print 'end tran'語句將不會被運行,所以我們很難在SQL Server 2000的T-SQL中對死鎖進行進一步的處理。

現在不同了,SQL Server 2005可以在T-SQL中對異常進行捕獲,這樣就給我們提供了一條處理死鎖的途徑:

下面利用的try ... catch來解決死鎖。

SET XACT_ABORT ON

declare @r int set @r = 1 while @r <= 3 begin begin tran begin try;;;;; insert into Orders(CustomerId) values('ALFKI') waitfor delay '00:00:05' select * from Orders where CustomerId = 'ALFKI' commit break end try begin catch rollback waitfor delay '00:00:03' set @r = @r + 1 continue end catch end 解決方法當然就是重試,但捕獲錯誤是前提。rollback后面的waitfor不可少,發生沖突后需要等待一段時間,@retry數目可以調整以應付不同的要求。

但是現在又面臨一個新的問題: 錯誤被掩蓋了,一但問題發生并且超過3次,異常卻不會被拋出。SQL Server 2005 有一個RaiseError語句,可以拋出異常,但卻不能直接拋出原來的異常,所以需要重新定義發生的錯誤,現在,解決方案變成了這樣:

declare @r int set @r = 1 while @r <= 3 begin begin tran begin try;;;;; insert into Orders(CustomerId) values('ALFKI') waitfor delay '00:00:05' select * from Orders where CustomerId = 'ALFKI' commit break end try begin catch rollback waitfor delay '00:00:03' set @r = @r + 1 continue end catch end

if ERROR_NUMBER() <> 0 begin declare @ErrorMessage nvarchar(4000); declare @ErrorSeverity int; declare @ErrorState int;

select; @ErrorMessage = ERROR_MESSAGE(), @ErrorSeverity = ERROR_SEVERITY(), @ErrorState = ERROR_STATE();

raiserror (@ErrorMessage, @ErrorSeverity, @ErrorState ); end 我希望將來SQL Server 2005能夠直接拋出原有異常,比如提供一個無參數的RaiseError。

因此方案有點臃腫,但將死鎖問題封裝到T-SQL中有助于明確職責,提高高層系統的清晰度。現在,對于DataAccess的代碼,或許再也不需要考慮死鎖問題了。

出處:Walkdan's blog

標簽: Sql Server 數據庫
主站蜘蛛池模板: 纳米涂料品牌 防雾抗污纳米陶瓷涂料厂家_虹瓷科技 | 招商帮-一站式网络营销服务|互联网整合营销|网络推广代运营|信息流推广|招商帮企业招商好帮手|搜索营销推广|短视视频营销推广 | 坏男孩影院-提供最新电影_动漫_综艺_电视剧_迅雷免费电影最新观看 | CCC验厂-家用电器|服务器CCC认证咨询-奥测世纪 | 天坛家具官网| 沈飞防静电地板__机房地板-深圳市沈飞防静电设备有限公司 | 微学堂-电动能源汽车评测_电动车性能分享网| 纯化水设备-EDI-制药-实验室-二级反渗透-高纯水|超纯水设备 | 2025世界机器人大会_IC China_半导体展_集成电路博览会_智能制造展览网 | 浙江筋膜枪-按摩仪厂家-制造商-肩颈按摩仪哪家好-温州市合喜电子科技有限公司 | 淘剧影院_海量最新电视剧,免费高清电影随心观看 | 美国PARKER齿轮泵,美国PARKER柱塞泵,美国PARKER叶片泵,美国PARKER电磁阀,美国PARKER比例阀-上海维特锐实业发展有限公司二部 | 东莞工厂厂房装修_无尘车间施工_钢结构工程安装-广东集景建筑装饰设计工程有限公司 | 热回收盐水机组-反应釜冷水机组-高低温冷水机组-北京蓝海神骏科技有限公司 | 基本型顶空进样器-全自动热脱附解吸仪价格-AutoHS全模式-成都科林分析技术有限公司 | 定做大型恒温循环水浴槽-工业用不锈钢恒温水箱-大容量低温恒温水槽-常州精达仪器 | 葡萄酒灌装机-食用油灌装机-液体肥灌装设备厂家_青州惠联灌装机械 | 安全阀_弹簧式安全阀_美标安全阀_工业冷冻安全阀厂家-中国·阿司米阀门有限公司 | 扫地车厂家-山西洗地机-太原电动扫地车「大同朔州吕梁晋中忻州长治晋城洗地机」山西锦力环保科技有限公司 | 闪蒸干燥机-喷雾干燥机-带式干燥机-桨叶干燥机-[常州佳一干燥设备] | 福州仿石漆加盟_福建仿石漆厂家-外墙仿石漆加盟推荐铁壁金钢(福建)新材料科技有限公司有保障 | 上海风淋室_上海风淋室厂家_上海风淋室价格_上海伯淋 | 宿松新闻网 宿松网|宿松在线|宿松门户|安徽宿松(直管县)|宿松新闻综合网站|宿松官方新闻发布 | 环氧树脂地坪漆_济宁市新天地漆业有限公司| 广州企亚 - 数码直喷、白墨印花、源头厂家、透气无手感方案服务商! | 电液推杆生产厂家|电动推杆|液压推杆-扬州唯升机械有限公司 | T恤衫定做,企业文化衫制作订做,广告T恤POLO衫定制厂家[源头工厂]-【汉诚T恤定制网】 | 台湾Apex减速机_APEX行星减速机_台湾精锐减速机厂家代理【现货】-杭州摩森机电 | 老城街小面官网_正宗重庆小面加盟技术培训_特色面馆加盟|牛肉拉面|招商加盟代理费用多少钱 | 单电机制砂机,BHS制砂机,制沙机设备,制砂机价格-正升制砂机厂家 单级/双级旋片式真空泵厂家,2xz旋片真空泵-浙江台州求精真空泵有限公司 | 免费分销系统 — 分销商城系统_分销小程序开发 -【微商来】 | 碳化硅,氮化硅,冰晶石,绢云母,氟化铝,白刚玉,棕刚玉,石墨,铝粉,铁粉,金属硅粉,金属铝粉,氧化铝粉,硅微粉,蓝晶石,红柱石,莫来石,粉煤灰,三聚磷酸钠,六偏磷酸钠,硫酸镁-皓泉新材料 | 铝扣板-铝方通-铝格栅-铝条扣板-铝单板幕墙-佳得利吊顶天花厂家 elisa试剂盒价格-酶联免疫试剂盒-猪elisa试剂盒-上海恒远生物科技有限公司 | 顺辉瓷砖-大国品牌-中国顺辉| 铸铝门厂家,别墅大门庭院大门,别墅铸铝门铜门[十大品牌厂家]军强门业 | 烟台螺纹,烟台H型钢,烟台钢材,烟台角钢-烟台市正丰金属材料有限公司 | 中医治疗皮肤病_潍坊银康医院「山东」重症皮肤病救治平台 | 通辽信息港 - 免费发布房产、招聘、求职、二手、商铺等信息 www.tlxxg.net | 河南档案架,档案密集架,手动密集架,河南密集架批发/报价 | 基本型顶空进样器-全自动热脱附解吸仪价格-AutoHS全模式-成都科林分析技术有限公司 | 东莞市踏板石餐饮管理有限公司_正宗桂林米粉_正宗桂林米粉加盟_桂林米粉加盟费-东莞市棒子桂林米粉 |