您的位置:首页 > 数据库

通过名字查找数据库名的通用存储过程

2006-06-26 15:01 507 查看
/*
很多时候,我们的sql server有很多数据库,当我们想得知有那些数据库包含有某个表、存储过程、视图、函数名,
例如想知道有那些数据库包含有表'Vender',
可以用下面的存储过程找出来所有包含表、存储过程、视图、函数名字为'Vender'的数据库名字。
*/

use master
go

if exists (select * from sysobjects where name = 'sp_getdbnamefromtb')
begin
print 'drop procedure sp_getdbnamefromtb...'
drop PROCEDURE sp_getdbnamefromtb
end
go

create procedure sp_getdbnamefromtb(@tb_name varchar(50))-- 寻找的表名
as
declare @n int
declare @db_name varchar(50) -- 临时数据库名变量
declare @sql nvarchar(200)
declare @tb_find table(name varchar(50)) --结果存放区

declare v_db_list cursor for select name from sysdatabases

begin
open v_db_list

fetch next from v_db_list into @db_name;

while (@@fetch_status =0)
begin
select @sql = 'select @count = count(1) from '+@db_name +'.dbo.sysobjects where name = ''' + @tb_name +''''
exec sp_executesql @sql,N'@count int out',@n out
if @n > 0
begin
insert into @tb_find(name) values(@db_name);
end
fetch next from v_db_list into @db_name;
end

select * from @tb_find
close v_db_list;
deallocate v_db_list;
end
go

use master
exec sp_getdbnamefromtb 'sysobjects'
go
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: