Sqlserver
 sql >> Datenbank >  >> RDS >> Sqlserver

SQL Server 2008 - finden Sie heraus, welche Tabellen einen bestimmten Text enthalten

Um Tabellenspalten zu finden, verwenden Sie:

SELECT table_name=sysobjects.name,
         column_name=syscolumns.name
    FROM sysobjects 
    JOIN syscolumns ON sysobjects.id = syscolumns.id
    JOIN systypes ON syscolumns.xtype=systypes.xtype
   WHERE sysobjects.xtype='U'
ORDER BY sysobjects.name,syscolumns.colid

Wenn Sie möchten, dass Daten in den Tabellen dynamisches SQL verwenden, können Sie etwas in diesen Zeilen tun:

Declare @Sql varChar(100)
Declare @Temp Table (Ind INT, TableName nvarchar(100))

Insert Into @Temp
Select Row_Number() Over(Order BY [Name]), [Name]
FROM
(
    Select [Name]
    from sys.tables
) AS D

Declare @index int
Set @index = 1
while @index < (Select Count(*) From @Temp)
begin
SET @SQL = ' Select * From ' + (Select TableName From @Temp Where Ind = @index)


exec (@SQL)
Set @index = @index + 1
End