SQL SERVER2000新建立数据库,系统总是说“未能取得MODEL的排他锁,请稍后在试“

SQL SERVER2000新建立数据库,系统总是说“未能取得MODEL的排他锁,请稍后在试“,第1张

在查询分析器中运行如下代码即可:

use master

declare @sql varchar(100)

while 1=1

begin

select top 1 @sql = 'kill '+cast(spid as varchar(3))

from master..sysprocesses

where spid >50 and spid <>@@spid

if @@rowcount = 0

break

exec(@sql)

end

原因分析:

死锁是指在某组资源中,两个或两个以上的线程在执行过程中,在争夺某一资源时而造成互相等待的现象,若无外力的作用下,它们都将无法推进下去,死时就可能会产生死锁,这些永远在互相等待的进程称为死锁线程。简单的说,进程A等待进程B释放他的资源,B又等待A释放他的资源,这样互相等待就形成死锁。

数据库是一个多用户使用的共享资源。当多个用户并发地存取数据时,在数据库中就会产生多个事务同时存取同一数据的情况。若对并发 *** 作不加控制就可能会读取和存储不正确的数据,破坏数据库的一致性。

加锁是实现数据库并发控制的一个非常重要的技术。当事务在对某个数据对象进行 *** 作前,先向系统发出请求,对其加锁。加锁后事务就对该数据对象有了一定的控制,在该事务释放锁之前,其他的事务不能对此数据对象进行更新 *** 作。

在数据库中有两种基本的锁类型:排它锁(Exclusive Locks,即X锁)和共享锁(Share Locks,即S锁)。当数据对象被加上排它锁时,其他的事务不能对它读取和修改。加了共享锁的数据对象可以被其他事务读取,但不能修改。数据库利用这两种基本的锁类型来对数据库的事务进行并发控制。

扩展资料:

排它锁和共享锁的不同之处:

1、共享锁(S锁):如果事务T对数据A加上共享锁后,则其他事务只能对A再加共享锁,不能加排他锁。获准共享锁的事务只能读数据,不能修改数据。

排他锁(X锁):如果事务T对数据A加上排他锁后,则其他事务不能再对A加任任何类型的封锁。获准排他锁的事务既能读数据,又能修改数据。

2、共享锁下其它用户可以并发读取,查询数据。但不能修改,增加,删除数据,资源共享。

3、共享锁又称为读锁(Share lock,简记为S锁),若事务T对数据对象A加上S锁,则其它事务只能再对A加S锁,而不能加X锁,直到T释放A上的S锁。

参考资料:百度百科-排它锁

参考资料:百度百科-共享锁

半专业回答:

1, 这是个疑问句吗

2,如果只是 读 *** 作是不会加锁的

3,事务2 什么 *** 作都不行

4,事务2 可以加共享锁,不能加排他锁

问题补充回答

读 *** 作就是select ,任何时刻都可以,因为是非阻塞读,由UNDO机制实现

共享锁是保证表结构不能被更改,但是可以更改没有加排他锁的数据

共享锁是表级的,排他锁是行级的


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/6890747.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-29
下一篇 2023-03-29

发表评论

登录后才能评论

评论列表(0条)

保存