【问题标题】:How to find tables and columns containing specified column value如何查找包含指定列值的表和列
【发布时间】:2015-03-02 12:34:30
【问题描述】:

在 T-SQL 中是否可以给我一个包含指定列值的表和列的列表?

例如,我从 SQL Server 数据库中生成了一份员工报告,该报告在其中一列中将“John”显示为姓名。现在我想找出“John”作为字段值出现在数据库中任何表/列中的位置。

所以在英语中我的查询应该听起来像;

Select table, column 
from database A 
where field = 'John'

谢谢

【问题讨论】:

标签: sql-server tsql


【解决方案1】:

试试这个过程

CREATE PROCEDURE FindMyData_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

          PRINT @SQL

          EXEC SP_EXECUTESQL
            @SQL,
            @PARAMETERS,
            @DataExists = @DataExists OUTPUT

          IF @DataExists = 1
            UPDATE @Temp
            SET    DataFound = 1
            WHERE  RowId = @i

          SET @i = @i + 1
      END

    SELECT SchemaName,
           TableName,
           ColumnName
    FROM   @Temp
    WHERE  DataFound = 1

EXEC FindMyData_String
  @DataToFind='Enter Your String'

【讨论】:

    猜你喜欢
    • 2018-08-10
    • 1970-01-01
    • 2020-08-30
    • 1970-01-01
    • 2013-03-19
    • 1970-01-01
    • 2011-02-25
    • 2015-02-27
    • 1970-01-01
    相关资源
    最近更新 更多