This is a neat procedure to search for a string in all MS SQL database:
CREATE PROCEDURE Find_My_String
@DataToFind NVARCHAR(4000),
@ExactMatch BIT = 0
AS
SET NOCOUNT ON
DECLARE @Temp TABLE(
RowId INT IDENTITY(1,1),
SchemaName sysname,
TableName sysname,
ColumnName SysName,
DataType VARCHAR(100),
DataFound BIT
)
INSERT INTO @Temp(TableName,SchemaName, ColumnName, DataType)
SELECT C.Table_Name,C.TABLE_SCHEMA, C.Column_Name, C.Data_Type
FROM Information_Schema.Columns AS C
INNER JOIN Information_Schema.Tables AS T ON C.Table_Name = T.Table_Name
AND C.TABLE_SCHEMA = T.TABLE_SCHEMA
WHERE Table_Type = 'Base Table'
AND Data_Type IN ('ntext','text','nvarchar','nchar','varchar','char')
DECLARE @i INT
DECLARE @MAX INT
DECLARE @TableName sysname
DECLARE @ColumnName sysname
DECLARE @SchemaName sysname
DECLARE @SQL NVARCHAR(4000)
DECLARE @PARAMETERS NVARCHAR(4000)
DECLARE @DataExists BIT
DECLARE @SQLTemplate NVARCHAR(4000)
SELECT @SQLTemplate = CASE WHEN @ExactMatch = 1
THEN 'IF EXISTS(SELECT *
FROM ReplaceTableName
WHERE CONVERT(nVarChar(4000), [ReplaceColumnName])
= ''' + @DataToFind + '''
)
SET @DataExists = 1
ELSE
SET @DataExists = 0'
ELSE 'IF EXISTS(SELECT *
FROM ReplaceTableName
WHERE CONVERT(nVarChar(4000), [ReplaceColumnName])
LIKE ''%' + @DataToFind + '%''
)
SET @DataExists = 1
ELSE
SET @DataExists = 0'
END,
@PARAMETERS = '@DataExists Bit OUTPUT',
@i = 1
SELECT @i = 1, @MAX = MAX(RowId)
FROM @Temp
WHILE @i <= @MAX
BEGIN
SELECT @SQL = REPLACE(
REPLACE(
@SQLTemplate, 'ReplaceTableName', QUOTENAME(SchemaName) + '.' + QUOTENAME(TableName)
),
'ReplaceColumnName', ColumnName
)
FROM @Temp
WHERE RowId = @i
EXEC SP_EXECUTESQL @SQL, @PARAMETERS, @DataExists = @DataExists OUTPUT
IF @DataExists =1
BEGIN
PRINT @SQL
UPDATE @Temp SET DataFound = 1 WHERE RowId = @i
END
SET @i = @i + 1
END
SELECT SchemaName, TableName, ColumnName
FROM @Temp
WHERE DataFound = 1
GO
After you created this procedure, do a search with the following:
exec [dbo].[Find_My_String] ‘searchstring’, 0