MSSQL所有表中查找某个字段中的一个数据。100分悬赏

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MSSQL所有表中查找某个字段中的一个数据。100分悬赏相关的知识,希望对你有一定的参考价值。

比如我想在 所有表里的字段中找查找aas
应该怎么写命令?

可以在我的百度空间里看:http://hi.baidu.com/fupx2008/blog/item/8b4841bf6124401619d81fb6.html
---查询一(所)表所有字段包含xx的信息
--1、查找所表所对应的字段
Select Distinct A.name As columnname,object_name(A.id)As tablename Into T_Search
From Syscolumns A,Sysobjects B, Systypes C
Where A.id=B.ID And B.xtype='u' --And B.Name='Dept' ---如果只查一个表,把 And B.Name='Dept' 加上,并把"Dept"换成你的表
And C.name in('varchar','nvarchar','char','nchar','text','ntext')
And object_name(A.id)<>'T_Search' ---排除刚刚生成的表T_Search
go

---2、创建函数
Create function Search_Info(@tableName varchar(1000),@keyword varchar(1000))
Returns varchar(8000)
As
Begin
Declare @sql varchar(8000)
Set @sql='Select * From '+@tableName +' Where 1=1'
Select @sql=@sql+' Or '+ columnname +' Like ''%'+@keyword+'%''' From T_Search ---如果是精确查找就把%去掉
Where tablename=@tablename
Return Replace(@sql,'1=1 Or','')
End
go

---3、查找所要包含的信息
Declare @Exec_SQL varchar(8000)
Set @Exec_SQL=(Select dbo.Search_Info(tableName,'aas') From T_Search Group By tablename)
Exec(@Exec_SQL)

---4、删除表和函数
/*
Drop Table T_Search
Drop function dbo.Search_Info
*/
参考技术A select attr_name
from (select * from tab) -- 找出所有的表
where attr_name = 'aas'

语法应该的改改,想法是找出所有的表后就搜索。
怎么样join所有的表就看你自己了。

以上是关于MSSQL所有表中查找某个字段中的一个数据。100分悬赏的主要内容,如果未能解决你的问题,请参考以下文章

asp读取MSSQL数据库中某个字段的值

如何查询出一个数据库中的某个表中的某个字段?

怎么在数据库所有的表中查找数据

Sql查询一个表中除了某个字段以外的所有字段的方法?

SQL中如何根据字段名查找该字段名存在于数据库的哪些表中?

MYSQL过滤表中某几个字段重复的数据