一尘不染

有没有一种方法可以将表名指定为字符串?

sql

让我们说我有这样的查询:

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仍然可以使用吗?


阅读 117

收藏
2021-03-10

共1个答案

一尘不染

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