国产一级a片免费看高清,亚洲熟女中文字幕在线视频,黄三级高清在线播放,免费黄色视频在线看

打開APP
userphoto
未登錄

開通VIP,暢享免費電子書等14項超值服

開通VIP
SQL Server2000中死鎖經(jīng)驗總結(jié)
雖然不能完全避免死鎖,但可以使死鎖的數(shù)量減至最少。將死鎖減至最少可以增加事務(wù)的吞吐量并減少系統(tǒng)開銷,因為只有很少的事務(wù):
 
 
回滾,而回滾會取消事務(wù)執(zhí)行的所有工作。
由于死鎖時回滾而由應(yīng)用程序重新提交。

下列方法有助于最大限度地降低死鎖:
 
 
按同一順序訪問對象。
避免事務(wù)中的用戶交互。
保持事務(wù)簡短并在一個批處理中。
使用低隔離級別。
使用綁定連接。

按同一順序訪問對象
 
如果所有并發(fā)事務(wù)按同一順序訪問對象,則發(fā)生死鎖的可能性會降低。例如,如果兩個并發(fā)事務(wù)獲得 Supplier 表上的鎖,然后獲得 Part 表上的鎖,則在其中一個事務(wù)完成之前,另一個事務(wù)被阻塞在 Supplier 表上。第一個事務(wù)提交或回滾后,第二個事務(wù)繼續(xù)進行。不發(fā)生死鎖。將存儲過程用于所有的數(shù)據(jù)修改可以標(biāo)準(zhǔn)化訪問對象的順序。
避免事務(wù)中的用戶交互
 
避免編寫包含用戶交互的事務(wù),因為運行沒有用戶交互的批處理的速度要遠遠快于用戶手動響應(yīng)查詢的速度,例如答復(fù)應(yīng)用程序請求參數(shù)的提示。例如,如果事務(wù)正在等待用戶輸入,而用戶去吃午餐了或者甚至回家過周末了,則用戶將此事務(wù)掛起使之不能完成。這樣將降低系統(tǒng)的吞吐量,因為事務(wù)持有的任何鎖只有在事務(wù)提交或回滾時才會釋放。即使不出現(xiàn)死鎖的情況,訪問同一資源的其它事務(wù)也會被阻塞,等待該事務(wù)完成。
 
保持事務(wù)簡短并在一個批處理中
 
在同一數(shù)據(jù)庫中并發(fā)執(zhí)行多個需要長時間運行的事務(wù)時通常發(fā)生死鎖。事務(wù)運行時間越長,其持有排它鎖或更新鎖的時間也就越長,從而堵塞了其它活動并可能導(dǎo)致死鎖。
 
保持事務(wù)在一個批處理中,可以最小化事務(wù)的網(wǎng)絡(luò)通信往返量,減少完成事務(wù)可能的延遲并釋放鎖。
 
使用低隔離級別
 
確定事務(wù)是否能在更低的隔離級別上運行。執(zhí)行提交讀允許事務(wù)讀取另一個事務(wù)已讀取(未修改)的數(shù)據(jù),而不必等待第一個事務(wù)完成。使用較低的隔離級別(例如提交讀)而不使用較高的隔離級別(例如可串行讀)可以縮短持有共享鎖的時間,從而降低了鎖定爭奪。
 
使用綁定連接
 
使用綁定連接使同一應(yīng)用程序所打開的兩個或多個連接可以相互合作。次級連接所獲得的任何鎖可以象由主連接獲得的鎖那樣持有,反之亦然,因此不會相互阻塞
 
檢測死鎖
 
如果發(fā)生死鎖了,我們怎么去檢測具體發(fā)生死鎖的是哪條SQL語句或存儲過程?
 
這時我們可以使用以下存儲過程來檢測,就可以查出引起死鎖的進程和SQL語句。SQL Server自帶的系統(tǒng)存儲過程sp_who和sp_lock也可以用來查找阻塞和死鎖, 但沒有這里介紹的方法好用。

 
 
use master
go
create procedure sp_who_lock
as
begin
declare @spid int,@bl int,
 @intTransactionCountOnEntry  int,
        @intRowcount    int,
        @intCountProperties   int,
        @intCounter    int
 create table #tmp_lock_who (
 id int identity(1,1),
 spid smallint,
 bl smallint)
 
 IF @@ERROR<>0 RETURN @@ERROR
 
 insert into #tmp_lock_who(spid,bl) select  0 ,blocked
   from (select * from sysprocesses where  blocked>0 ) a
   where not exists(select * from (select * from sysprocesses where  blocked>0 ) b
   where a.blocked=spid)
   union select spid,blocked from sysprocesses where  blocked>0
 IF @@ERROR<>0 RETURN @@ERROR
 
-- 找到臨時表的記錄數(shù)
 select  @intCountProperties = Count(*),@intCounter = 1
 from #tmp_lock_who
 
 IF @@ERROR<>0 RETURN @@ERROR
 
 if @intCountProperties=0
  select '現(xiàn)在沒有阻塞和死鎖信息' as message
-- 循環(huán)開始
while @intCounter <= @intCountProperties
begin
-- 取第一條記錄
  select  @spid = spid,@bl = bl
  from #tmp_lock_who where Id = @intCounter
 begin
  if @spid =0
            select '引起數(shù)據(jù)庫死鎖的是: '+ CAST(@bl AS VARCHAR(10)) + '進程號,其執(zhí)行的SQL語法如下'
 else
            select '進程號SPID:'+ CAST(@spid AS VARCHAR(10))+ '被' + '進程號SPID:'+ CAST(@bl AS VARCHAR(10)) +'阻塞,其當(dāng)前進程執(zhí)行的SQL語法如下'
 DBCC INPUTBUFFER (@bl )
 end
-- 循環(huán)指針下移
 set @intCounter = @intCounter + 1
end
drop table #tmp_lock_who
return 0
end

 
 
殺死鎖和進程
 
如何去手動的殺死進程和鎖?最簡單的辦法,重新啟動服務(wù)。但是這里要介紹一個存儲過程,通過顯式的調(diào)用,可以殺死進程和鎖。
 
 
use master
go
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_killspid]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
drop procedure [dbo].[p_killspid]
GO
create proc p_killspid
@dbname varchar(200)    --要關(guān)閉進程的數(shù)據(jù)庫名
as 
    declare @sql  nvarchar(500) 
    declare @spid nvarchar(20)
    declare #tb cursor for
        select spid=cast(spid as varchar(20)) from master..sysprocesses where dbid=db_id(@dbname)
    open #tb
    fetch next from #tb into @spid
    while @@fetch_status=0
    begin 
        exec('kill '+@spid)
        fetch next from #tb into @spid
    end 
    close #tb
    deallocate #tb
go
--用法 
exec p_killspid  'newdbpy'

 
 
查看鎖信息
 
如何查看系統(tǒng)中所有鎖的詳細信息?在企業(yè)管理管理器中,我們可以看到一些進程和鎖的信息,這里介紹另外一種方法。
 
 
--查看鎖信息
create table #t(req_spid int,obj_name sysname)
declare @s nvarchar(4000)
    ,@rid int,@dbname sysname,@id int,@objname sysname
declare tb cursor for
    select distinct req_spid,dbname=db_name(rsc_dbid),rsc_objid
    from master..syslockinfo where rsc_type in(4,5)
open tb
fetch next from tb into @rid,@dbname,@id
while @@fetch_status=0
begin
    set @s='select @objname=name from ['+@dbname+']..sysobjects where id=@id'
    exec sp_executesql @s,N'@objname sysname out,@id int',@objname out,@id
    insert into #t values(@rid,@objname)
    fetch next from tb into @rid,@dbname,@id
end
close tb
deallocate tb
select 進程id=a.req_spid
    ,數(shù)據(jù)庫=db_name(rsc_dbid)
    ,類型=case rsc_type when 1 then 'NULL 資源(未使用)'
        when 2 then '數(shù)據(jù)庫'
        when 3 then '文件'
        when 4 then '索引'
        when 5 then '表'
        when 6 then '頁'
        when 7 then '鍵'
        when 8 then '擴展盤區(qū)'
        when 9 then 'RID(行 ID)'
        when 10 then '應(yīng)用程序'
    end
    ,對象id=rsc_objid
    ,對象名=b.obj_name
    ,rsc_indid
 from master..syslockinfo a left join #t b on a.req_spid=b.req_spid
go
drop table #t

 
 
總結(jié)
雖然不能完全避免死鎖,但我們可以將死鎖減至最少,并通過一定的方法來檢測死鎖。

本文來自CSDN博客,轉(zhuǎn)載請標(biāo)明出處:http://blog.csdn.net/mshust2006/archive/2006/10/13/1333393.aspx
本站僅提供存儲服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊舉報
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
SQL Server死鎖的分析
數(shù)據(jù)庫死鎖導(dǎo)致網(wǎng)站站點訪問不了之解決方案
SQL Server死鎖總結(jié)
死鎖產(chǎn)生的原因和解鎖的方法
sqlserver數(shù)據(jù)庫還原存儲過程腳本
sqlserver2008 死鎖解決方法及性能優(yōu)化方法
更多類似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長圖 關(guān)注 下載文章
綁定賬號成功
后續(xù)可登錄賬號暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點擊這里聯(lián)系客服!

聯(lián)系客服