在Sql Server 数据库中找到含某个词的所有字段

问题:找到含某个词的所有表和字段

思路:循环 INFORMATION_SCHEMA.COLUMNS  ,找到所有的表和列,并尝试用select count(1) 的方式 ,如果,返回值大于0,说明,存在,否则不存在。

注意点:INFORMATION_SCHEMA.COLUMNS 要进行DATA_TYPE='nvarchar'的筛选,这个根据你所查的值是什么 类型而定。

存储过程

   
CREATE proc [dbo].[sp_FindCol]
@strLookfor nvarchar(128)
as
begin
DECLARE @num int
DECLARE @sql nvarchar(400)
DECLARE @tablename nvarchar(128)
DECLARE @tableColumn nvarchar(128)
DECLARE @ParmDefinition nvarchar(128)
DECLARE tnames_cursor CURSOR
FOR
SELECT TABLE_NAME,COLUMN_NAME
FROM INFORMATION_SCHEMA.COLUMNS where DATA_TYPE='nvarchar'
OPEN tnames_cursor

FETCH NEXT FROM tnames_cursor INTO @tablename,@tableColumn
While @@fetch_status=0
Begin
set @sql='select @num = COUNT(1) from '+ @tablename+' where '+ @tableColumn+'='+''''+@strLookfor+''''
--print @sql
SET @ParmDefinition = N'@num int OUT,@tablename nvarchar(128),@tableColumn nvarchar(128),@strLookfor nvarchar(128)'

EXECUTE sp_executesql @sql,@ParmDefinition,@num OUT,@tablename,@tableColumn,@strLookfor
if @num<>0
begin
set @sql=N' insert into t1(A,B) values('''+@tablename+''','''+@tableColumn+''')'
--print @sql
--print @num
EXECUTE (@sql)
end
Fetch Next From tnames_cursor Into @tablename,@tableColumn
End
print @num
Close tnames_cursor
Deallocate tnames_cursor
end

 

t1 表结构如下:

CREATE TABLE [dbo].[t1](
[A] [nvarchar](128) NULL,
[B] [nvarchar](128) NULL
)


关于 INFORMATION_SCHEMA的更多信息见官方文档

 http://msdn.microsoft.com/zh-cn/library/ms188348(v=SQL.100).aspx

 http://msdn.microsoft.com/zh-cn/library/ms186778(v=SQL.100).aspx

posted on 2011-12-13 12:36  冰羽的世界  阅读(425)  评论(0编辑  收藏  举报