让我们说我有这样的查询:
SELECT * FROM ( SELECT * FROM ( SELECT * FROM DB.dbo.Table ) INNER JOIN DB.dbo.Table ON ...
通过在各处手动更改字符串,我使用不同的表多次运行此查询。我尝试声明以下内容:
DECLARE @tablename AS VARCHAR(255) SET @tablename = 'DB.dbo.Table'
但这似乎不起作用,因为它引发了一个错误,提示我必须先声明@tablename为表变量,然后才能使用它。我如何对表名进行模板化,如果可以的话,Intellisense仍然可以使用吗?
@tablename
您可以将其包装在EXEC语句中,如下所示:
declare @my_tablename nvarchar(100) = 'mytable'; exec(' SELECT * FROM ( SELECT * FROM ( SELECT * FROM ' + @my_tablename + ' ) INNER JOIN ' + @my_tablename + ' ON ...' );
但是不,在这种情况下,智能感知将无法正常工作。
如果您事先知道输出是什么样子,则可以声明一个临时表来保存结果,然后可以在不使用EXEC的情况下对其进行访问。您将在临时表上具有智能感知功能。
例如:
--this must match whatever your SELECT is going to return CREATE TABLE #results( FIELD1 INT ,FIELD2 NVARCHAR(100) ,FIELD3 BIT ); EXEC(' INSERT INTO #results(field1,field2,field3) SELECT FIELD1,FIELD2,FIELD3 FROM ' + @my_tablename ); select * from #results --you will have intellisense on #results