我已经成功编写了代码来动态联合多个数据库中的简单选择语句的结果。我想将数据库名称本身作为一个字段包含在内,以便我可以识别每条记录。修改下面的代码以实现这一目标的最佳方法是什么?
我目前的结果看起来像
字段 2、字段 3、字段 4 b、c、d 2、3、4
我不知道包含 (b,c,d) 的行来自哪个数据库。
我想确保我看到 field1, field2, field3, field4 First_DatabaseName, b,c,d Second_DatabaseName,2,3,4
在上面,我可以看到包含 (b,c,d) 的行来自 First_Database
DECLARE @sql varchar(max)
SELECT @sql = ISNULL(@sql + 'union all ',' ') + ' SELECT * FROM ' + name + '.dbo.CombinedProvider '
FROM sys.databases
WHERE name in ('First_DatabaseName', 'Second_DatabaseName')
EXEC (@sql)