首页 > 数据库

執行SQL出現Lock request time out period exceeded.(MicrosoftSQL Server,Error:1222)解決方案

时间:2009-04-28 15:17:30  作者:yoyoch1  我要投稿
Linux初探欢迎您的投稿,投放方法请点击这里查看,我们会定期赠送精美小礼品给优秀的投稿作者。海纳百川 取则行远!LinuxGoo欢迎您的到来。
今天執行SSIS出現了一個很奇怪的問題。執行一個packege居然把系統的資源消耗完了。尋找了半天,還沒有發現問題的根源,甚是納悶。於是重新執行,手動初始化Staging,發......

今天執行SSIS出現了一個很奇怪的問題。執行一個packege居然把系統的資源消耗完了。

尋找了半天,還沒有發現問題的根源,甚是納悶。於是重新執行,手動初始化Staging,發現Truncate一個table居然反應遲鈍,而其他table都是很快,問題終於發現。於是手動刪除table,出現了Lock request time out period exceeded.(MicrosoftSQL Server,Error:1222)。真是太興奮了!!!

解決方案:

首先sp_lock查看那個對象被鎖住:

SQL>Excec sp_lock

得到spid、dbid、objid、indid、type、resource、mode和status字段相應的數據。

Spid:SQL Server进程标识号。
Dbid:锁定资源的数据库标识号。
Objld:锁定资源的数据库对象标识号。
Indld:锁定资源的索引标识号。
Resource:锁定资源的描述信息。
Mode:锁定资源模式。
Status:请示状态,有GRANT、WAIT和CNVRT三种,分别表示锁处于锁定状态、等待状态和转换状态。

備註:spid是进程标识号码,用于识别到SQL 服务器的连接。要发现哪些用户和该spid相连,你就要执行存储过程sp_who,并将spid作为一个参数传输给该程序。dbid是锁定发生的数据库,你可以在主数据库中的sysdatabases表格中找到它。字段objid用来显示在数据库中锁定发生所在的对象。要查看这个对象,你可以在主数据库中的sysobjects表格中查询指定的objid。

再執行:

select * from sysobjects where id = objid 由上面得到的Lock objid

終於發現那個table被鎖住。

好!!Kill!!

SQL>kill 52

如果您需转载 執行SQL出現Lock request time out period exceeded.(MicrosoftSQL Server,Error:1222)解決方案,请注明来自LinuxGoo.com,其版权归原作者所有。请广大网友留言时遵纪守法,使用文明用语。如果您在应用中有什么问题,请在下面留言,我们会尽快解答。
来顶一下
近回首页
返回首页
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表
相关文章
栏目热门