在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