0

このクエリを使用してデータベース内の文字列を検索しましたが、特定の DB で次のエラーが発生しました。

'seem' 付近の構文が正しくありません。

だからその理由が知りたい

CREATE TABLE #Results (ColumnName nvarchar(370), ColumnValue nvarchar(3630)) 

SET NOCOUNT ON 

DECLARE @TableName nvarchar(256), @ColumnName nvarchar(128), @SearchStr2 nvarchar(110) 

SET @TableName = '' 

SET @SearchStr2 = quotename( '%NQF%0028a%' , '''' ) 

WHILE @TableName IS NOT NULL 
BEGIN 
   SET @ColumnName = '' 
   SET @TableName = 

   (
     SELECT min(quotename(TABLE_SCHEMA) + '.' + quotename(TABLE_NAME)) 
     FROM INFORMATION_SCHEMA.TABLES 
     WHERE TABLE_TYPE = 'BASE TABLE' 
       AND quotename(TABLE_SCHEMA) + '.' + quotename(TABLE_NAME) > @TableName 
       AND objectproperty(object_id(quotename(TABLE_SCHEMA) + '.' + quotename(TABLE_NAME)), 'IsMSShipped') = 0 
   ) 

   WHILE (@TableName IS NOT NULL) AND (@ColumnName IS NOT NULL) 
   BEGIN 
      SET @ColumnName = (SELECT min(quotename(COLUMN_NAME)) 
                         FROM INFORMATION_SCHEMA.COLUMNS 
                         WHERE TABLE_SCHEMA = parsename(@TableName, 2) 
                           AND TABLE_NAME = parsename(@TableName, 1) 
                           AND DATA_TYPE IN ('char', 'varchar', 'nchar', 'nvarchar') 
                           AND quotename(COLUMN_NAME ) > @ColumnName ) 

      IF @ColumnName IS NOT NULL 
      BEGIN 
          INSERT INTO #Results 
            EXEC 
             ('SELECT ''' + @TableName + '.' + @ColumnName + ''', LEFT(' + @ColumnName + ', 3630)    
    FROM ' + @TableName + ' (NOLOCK) ' + 

    ' WHERE ' + @ColumnName + ' LIKE ' + @SearchStr2 

) 

END 

END 

END 


SELECT ColumnName , ColumnValue FROM #Results**strong text**
4

1 に答える 1

1

テーブル名にスペースが含まれているようです。名前の一部に「SEEM」が含まれているテーブルを確認し、可能であればスペースを削除します。テーブル名の変更がオプションでない場合は、@TableName変数を[]

于 2013-10-29T06:49:18.223 に答える