2016-07-20 13 views
0

whileループを使用せずに次のコードを書くにはどうすればよいですか?この場合、whileループを回避する別の方法はありますか?SQLのwhileループの代替ソリューション

ここ
SELECT @count = COUNT(*) from CommonTables 

While(@count > 0) 
BEGIN 
select top 1 @Sname = Schema_name,@Tname = Name from CommonTables 


SET @sql = '' 
SET @sql = 'insert into #Temp1 select '''[email protected]+''','''[email protected]+''',column_name,data_type,character_maximum_length FROM '[email protected]+'.information_schema.columns 
WHERE table_name = '''[email protected]+''' and TABLE_SCHEMA = '''[email protected]+'''' 

EXEC SP_EXECUTESQL @SQL 

SET @sql = '' 
SET @sql = 'insert into #Temp2 select '''[email protected]+''','''[email protected]+''',column_name,data_type,character_maximum_length FROM '[email protected]+'.information_schema.columns 
WHERE table_name = '''[email protected]+''' and TABLE_SCHEMA = '''[email protected]+'''' 

EXEC SP_EXECUTESQL @SQL 

DELETE from CommonTables where Name = @Tname and Schema_name = @Sname 

SELECT @count = COUNT(*) from CommonTables 

END 

CommonTablesは全くループを必要としない2つのデータベース(DB1とDB2)

答えて

0

に共通しているテーブルのリストが含まれています。

select @sql = isnull(@sql, '') 
     + N'INSERT INTO #Temp1 ' 
     + N'SELECT table_schema, table_name,column_name,data_type,character_maximum_length ' 
     + N'FROM ' + QUOTENAME(@DB1) + '.INFORMATION_SCHEMA.COLUMNS ' 
     + N'WHERE table_name = ''' + Name + ''' and TABLE_SCHEMA = ''' + Schema_name + ''';' + char(13) 
from CommonTables 

print @sql 
exec sp_executesql @sql 

2 DBに対して2つの別個のsp_execute文が必要ない場合は、あなたは、おかげでたくさん:)それがうまく機能している

、ここでは、クエリ

select @sql = isnull(@sql, '') 
     + N'insert into ' + db.temptbl + ' ' 
     + N'SELECT TABLE_SCHEMA,TABLE_NAME,COLUMN_NAME,DATA_TYPE,CHARACTER_MAXIMUM_LENGTH ' 
     + N'FROM ' + QUOTENAME(db.dbname) + '.INFORMATION_SCHEMA.COLUMNS ' 
     + N'WHERE TABLE_NAME = ''' + Name + ''' AND TABLE_SCHEMA = ''' + Schema_name + ''';' + char(13) 
from CommonTables 
     cross join 
     (
      select temptbl = '#Temp1', dbname = 'DB1' union all 
      select temptbl = '#Temp2', dbname = 'DB2' 
     ) db 

print @sql 
exec sp_executesql @sql 
+0

ある1つのsp_executeに組み合わせることができます –

関連する問題