随笔 - 229  文章 - 2  评论 - 511  阅读 - 84万

一些锁的示例

 

复制代码
use userDatabase
go
if exists(select 1 from sys.tables where name='t')
    
drop table t
create table t(c1 int,c2 int)
create index index1 on t(c1)
insert into t values(1,1)
复制代码

 

--UPDATE lock

复制代码
set transaction isolation level repeatable read
begin tran
update t set c2=6 where c1=1
select resource_type,resource_description,resource_associated_entity_id,request_mode,request_type,request_status  
from sys.dm_tran_locks where request_session_id=@@spid   order by resource_type
rollback
go
复制代码

 

--SIX

复制代码
set transaction isolation level repeatable read 
begin tran 
select *from t with (paglock) 
update t set c2=6 where c1=1 
select resource_type,resource_description,resource_associated_entity_id,request_mode,request_type,request_status 
from sys.dm_tran_locks where request_session_id=@@spid order by resource_type 
rollback 
go 
复制代码

 

 

 

--SIU

 

复制代码
set transaction isolation level repeatable read 
begin tran 
select *from t with (paglock,index=index1) 
update t set c2=6 where c1=1 
select resource_type,resource_description,resource_associated_entity_id,request_mode,request_type,request_status 
from sys.dm_tran_locks where request_session_id=@@spid order by resource_type 
rollback 
go

复制代码

 

--1:167为索引页,1:165为数据页

 

 

--UIX

复制代码
set transaction isolation level repeatable read 
begin tran 
update t with(paglock) set c2=6 where c1=1 
update t set c1=6 where c1=1 
select resource_type,resource_description,resource_associated_entity_id,request_mode,request_type,request_status 
from sys.dm_tran_locks where request_session_id=@@spid order by resource_type 
rollback 
go 

复制代码

 

 

 

 

 

 

 

Request_status

create table ##session(sessionID int

 

WAIT

Time

Transaction 1

  

Transaction 2

1

 set transaction isolation level  read committed

  

set transaction isolation level  read committed

2

  

  

Begin tran

3

Delete from ##session

go

insert into ##session values(@@SPID)

go

  

 update t set c2=6 where c1=1

4

select *from t

   

5

   

select resource_type,resource_description,resource_associated_entity_id,request_mode,request_type,request_status

from sys.dm_tran_locks where request_session_id in (select sessionID from ##session)

6

  

  

rollback

   

 

 

CONVERT

Time

Transaction 1

  

Transaction 2

1

 set transaction isolation level  read committed

  

set transaction isolation level repeatable read

2

  

  

Begin tran

3

Delete from ##session

go

insert into ##session values(@@SPID)

  

 select *from t

4

 

update t set c2=6 where c1=1

   

5

   

select resource_type,resource_description,resource_associated_entity_id,request_mode,request_type,request_status

from sys.dm_tran_locks where request_session_id in (select sessionID from ##session)

6

  

  

rollback

posted on   stswordman  阅读(831)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
< 2009年1月 >
28 29 30 31 1 2 3
4 5 6 7 8 9 10
11 12 13 14 15 16 17
18 19 20 21 22 23 24
25 26 27 28 29 30 31
1 2 3 4 5 6 7

点击右上角即可分享
微信分享提示