我想声明一个服务器名称,并在插入语句中使用该名称。到目前为止,我得到的只是一条错误消息。
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 '.'.
我之前遇到过这个问题,发现的唯一解决方法是动态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)