小编典典

如何在目标数据库名称中的变量用于插入语句?

sql

我想声明一个服务器名称,并在插入语句中使用该名称。到目前为止,我得到的只是一条错误消息。

declare @machine nvarchar(6);
declare @bar nvarchar(3);
set @machine = 'Name00';
set @bar = 'foo'

insert into @machine.dbname.dbo.table (column1, column2)
select (column1, column2)
from table
where column1 = @bar

这给了我:

Msg 102, Level 15, State 1, Line 6
Incorrect syntax near '.'.

阅读 171

收藏
2021-04-14

共1个答案

小编典典

我之前遇到过这个问题,发现的唯一解决方法是动态sql

declare @machine nvarchar(6)
declare @bar nvarchar(3)
declare @sql varchar(2000)
set @machine = 'Name00'
set @bar = 'foo'


Set @sql ='insert into ' + @machine + '.dbname.dbo.table (column1, column2)
select (column1, column2)
from table
where column1 = ''' + @bar + ''''

--print (@sql)
exec (@sql)
2021-04-14