我使用下面的代码来检查临时表是否存在,如果它存在,则在重新创建之前删除表。只要我不改变列,它就可以工作。如果我稍后添加一个列,它会给出一个错误,说“无效列”。请让我知道我做错了什么。

IF OBJECT_ID('tempdb..#Results') IS NOT NULL
    DROP TABLE #Results

CREATE TABLE #Results
(
    Company                CHAR(3),
    StepId                TINYINT,
    FieldId                TINYINT,
)

select company, stepid, fieldid from #Results

--Works fine to this point

IF OBJECT_ID('tempdb..#Results') IS NOT NULL
    DROP TABLE #Results

CREATE TABLE #Results
(
    Company                CHAR(3),
    StepId                TINYINT,
    FieldId                TINYINT,
    NewColumn            NVARCHAR(50)
)

select company, stepid, fieldid, NewColumn from #Results

--Does not work

当前回答

我无法重现这个错误。

也许我没有理解这个问题。

下面的工作为我在SQL Server 2005,与额外的“foo”列出现在第二个选择结果:

IF OBJECT_ID('tempdb..#Results') IS NOT NULL DROP TABLE #Results
GO
CREATE TABLE #Results ( Company CHAR(3), StepId TINYINT, FieldId TINYINT )
GO
select company, stepid, fieldid from #Results
GO
ALTER TABLE #Results ADD foo VARCHAR(50) NULL
GO
select company, stepid, fieldid, foo from #Results
GO
IF OBJECT_ID('tempdb..#Results') IS NOT NULL DROP TABLE #Results
GO

其他回答

当我已经创建了临时表时,我通常会碰到这个错误;检查SQL语句错误的代码会看到“旧的”临时表,并在后面的语句中返回错误的列数,就好像临时表从未被删除过一样。

在创建了列更少的版本后,更改临时表中的列数后,删除表,然后运行查询。

您可以截断并重用临时表,而不是删除并重新创建它

IF OBJECT_ID('tempdb..#Results') IS NOT NULL
    Truncate TABLE #Results
else
    CREATE TABLE #Results
    (
        Company             CHAR(3),
        StepId              TINYINT,
        FieldId             TINYINT,
    )

如果您使用的是Sql Server 2016或Azure Sql数据库,则使用以下语法删除临时表并重新创建它。更多信息请点击MSDN

语法

DROP TABLE [IF EXISTS] [database_name .][schema_name]。| schema_name。table_name[,…]n]

查询:

DROP TABLE IF EXISTS #Results
CREATE TABLE #Results
  (
   Company             CHAR(3),
   StepId              TINYINT,
   FieldId             TINYINT,
  )

现在,如果您正在使用SQL Server(2016+)的新版本之一,则可以使用下面的语法。

DROP TABLE IF EXISTS schema.yourtable(even temporary tables #...)

这对我很有效,

IF OBJECT_ID('tempdb.dbo.#tempTable') IS NOT NULL 
DROP TABLE #tempTable; 

这下边。Dbo (Dbo只是您的模式)变得更加重要。

更改临时表中的列时,必须删除该表,然后才能再次运行查询。(是的,这很烦人。这正是你必须做的。)

我一直认为这是因为“无效列”检查是在查询运行之前由解析器完成的,因此它是基于删除表之前的列.....PNBS也是这么说的。