2012-04-27 5 views
1

私はSQL Server 2008を使用しており、次の例の作業中ですHEREデータベース内のすべてのテーブルを検索し、値を返しますか?

以下は、これまでのコードです。 (唯一の違いは、ストアドプロシージャからクエリに変換され、不要なスキーマ名が削除されたことです)

結果に別の列を追加し、最初の列のデータを与えます。値。つまり、各テーブルが主キーで始まる場合、結果にはデータが見つかった行の主キーが含まれます。これも可能ですか?ありがとう。

DECLARE @DataToFind nvarchar(MAX) = '' 
DECLARE @ExactMatch BIT = 0 

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 TableName, ColumnName 
FROM @Temp 
WHERE DataFound = 1 

答えて

1

主キーを返すことは絶対に可能です。

  • 各テーブルのプライマリキーの列がある場合は、その名前を決定します。あなたが単一の列に固執することができれば、それはあなたの人生をはるかに容易にします。
  • @PrimaryKeyValueにこの列の値を返すように変更@SQLTemplate@PrimaryKeyValue
  • を言って、このような何か主キー値の内容のための変数を追加します。

    SELECT @SQLTemplate = CASE WHEN @ExactMatch = 1 
              THEN 'select @PrimaryKeyValue = min(' + @PrimaryKeyColumnName + ') 
                from ReplaceTableName 
                where Convert(nVarChar(4000), [ReplaceColumnName]) = ''' + @DataToFind + ''')' 
              ELSE 'select @PrimaryKeyValue = min(' + @PrimaryKeyColumnName + ') 
                from ReplaceTableName 
                where Convert(nVarChar(4000), [ReplaceColumnName]) Like ''%' + @DataToFind + '%'')' 
             END, 
         @PARAMETERS = '@PrimaryKeyValue nvarchar(4000) OUTPUT', 
         @i = 1 
    
関連する問題