更新数据库对象依赖关系
2008-11-19 10:10:00 来源:WEB开发网 闂備線娼уΛ鎾箯閿燂拷闂備礁鎲¢崹鐢垫崲閹扮増鍎嶆い鎺戝€甸崑鎾斥槈濞嗗秳娌紓鍌氱▌閹凤拷濠电姭鎷冮崨顓濈捕闂侀潧娲ゅú銊╁焵椤掍胶鈯曢柕鍥╁仧缁辩偤鏁撻敓锟�闂備線娼уΛ鎾箯閿燂拷 闂備胶枪缁绘鈻嶉弴銏犳瀬闁绘劕鎼痪褔鏌曟繝蹇曠窗闁煎壊浜滈—鍐偓锝庡墮娴犙勭箾閸喎鐏ユい鏇樺劦椤㈡瑩鎮℃惔銇帮拷在sql server 中我们会通过邮件菜单来查看一个对象的依赖关系,但有些意外情况会造成查看结果并不是非常的准确!
可以尝试以下例子 :
第一步:颠倒顺序,创建一个缺失依赖关系的存储过程
Code
CREATE PROC dbo.TestRefresh1
as
EXEC dbo.TestRefresh2
EXEC dbo.TestRefresh3
EXEC dbo.TestRefresh4
EXEC dbo.TestRefresh5
EXEC dbo.TestRefresh6
GO
CREATE PROC dbo.TestRefresh2
AS SELECT 1
GO
CREATE PROC dbo.TestRefresh3
AS SELECT 1
GO
CREATE PROC dbo.TestRefresh4
AS SELECT 1
第二步: 查看一下这个存储过程的依赖关系
Code
EXEC sp_depends @objname = N'dbo.TestRefresh1'
在结果中并没有发现dbo.TestRefresh1同其他对象有任何的依赖关系 ,细心的朋友早就发现这个问题是因为创建存储过程时的顺序问题所致。假设我们的数据库中并不缺失相关对象,可以尝试用如下代码来更新他们的依赖关系:
Code
declare @cmd as nvarchar(max);
declare c cursor fast_forward for
select 'EXEC sys.sp_refreshsqlmodule ' + ''''+schema_name([schema_id])+'.'+ [Name]+'''' as cms from sys.objects where type='p'
open c
fetch next from c into @cmd ;
while @@fetch_status = 0
begin
exec(@cmd);
fetch next from c into @cmd;
end
close c;
deallocate c;
完成之后再次执行
Code
EXEC sp_depends @objname = N'dbo.TestRefresh1'
看看结果吧!
其实,针对这些特性,我们可以用上面这段脚本来检查生产数据库数据库存储过程的健康状况,发现缺失的依赖关系!虽然用处不大,毕竟是一个知识点。与大家分享
更多精彩
赞助商链接