Рассмотрим хранимую процедуру, которая читает таблицу DATADB и, например, создает синтаксис SELECT и запускает ее как динамический SQL
declare @SQL varchar(1000)
declare @table as table (Unid int, DSTABLE varchar(50))
INSERT INTO @table
select 1 as Unid, 'DatabaseOne' as DSTABLE union
select 2 as Unid, 'DatabaseTwo' as DSTABLE union
select 3 as Unid, 'DatabaseThree' as DSTABLE
SELECT @SQL = (STUFF((
SELECT ' ' + ' SELECT Unid FROM ' + QUOTENAME(DSTABLE) + '.[dbo].[Customers] UNION ALL'
FROM @table
FOR XML PATH('')
), 1, 2, '')
) -- Multiple rows to one row
SELECT @SQL = SUBSTRING(@SQL, 0, LEN(@SQL)-9) -- remove last UNION ALL
--exec (@SQL)
--print @SQL
Вывод
SELECT Unid FROM [DatabaseOne].[dbo].[Customers] UNION ALL
SELECT Unid FROM [DatabaseTwo].[dbo].[Customers] UNION ALL
SELECT Unid FROM [DatabaseThree].[dbo].[Customers]