您可以将其包装在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


