删除实例的所有临时表

Dib*_*tar 10 sql sql-server sql-server-2005

我想知道如果有可能有一个查询丢弃所有临时表?

我一直在尝试使用tempdb.sys.tables来解决问题,但我正在努力格式化name列以使其可以被删除 - 另一个使得事情变得有点棘手的因素通常是临时表名包含一个'_'意味着做一个替换变得更加繁琐(对我来说至少!)

有什么我可以使用它会删除所有临时表(本地或全局)而不必在命名的基础上单独删除它们?

谢谢!

Ric*_*iwi 14

临时表的重点是它们是......临时的.一旦他们超出范围

  • #temp create in stored proc:stored proc exits
  • #temp在会话中创建:会话断开连接
  • ## temp:创建它的会话断开连接

查询消失.如果您发现需要手动删除临时表,则需要重新审视如何使用它们.

对于全局的,这将生成并执行语句以放弃它们.

declare @sql nvarchar(max)
select @sql = isnull(@sql+';', '') + 'drop table ' + quotename(name)
from tempdb..sysobjects
where name like '##%'
exec (@sql)
Run Code Online (Sandbox Code Playgroud)

暂停其他会话的[全局]临时表是一个坏主意.

对于本地(对于此会话)临时表,只需断开连接并重新连接即可.

  • 这在您开发时很有用。当发生错误时,临时表不会被删除,从而中断会话中的修复和测试流程。所以是的,这个答案也值得#temp。 (3认同)

dsz*_*dsz 13

下面的版本避免了处理'_'s的所有麻烦.我只是想摆脱非全局临时表,因此'#[^#]%'在我的WHERE条款,删除[^#],如果你想删除全局临时表为好,或使用'##%',如果你想要放弃全局临时表.

DROP声明似乎很乐意使用'_'等等的全名,因此我们不需要操纵和编辑这些.该OBJECT_ID(...) NOT NULL让我避免了未通过我的会话创建的,大概是因为这些表不应该是"可见的"我的表,他们回来与此调用NULL.的QUOTENAME需要,以确保名称正确引用/逃脱.如果没有临时表,@d_sql则仍然是空字符串,因此我们在打印/执行之前检查它.

DECLARE @d_sql NVARCHAR(MAX)
SET @d_sql = ''

SELECT @d_sql = @d_sql + 'DROP TABLE ' + QUOTENAME(name) + ';
'
FROM tempdb..sysobjects
WHERE name like '#[^#]%'
AND OBJECT_ID('tempdb..'+QUOTENAME(name)) IS NOT NULL

IF @d_sql <> ''
BEGIN
    PRINT @d_sql
    -- EXEC( @d_sql )
END
Run Code Online (Sandbox Code Playgroud)

  • 有点令人惊讶的是`DROP TABLE [#bar______ ... __00000000000F];` 有效。我以前会想象它只能使用友好名称`DROP TABLE #bar` (2认同)

Mar*_*ith 5

在存储过程中,当proc执行完成时,它们会自动删除。

当我从存储过程中复制代码以调试它的一部分并且存储的proc不包含drop table命令时,通常会遇到这种情况。

按照接受的答案所述,关闭并重新打开连接。您可以在SSMS的“查询”菜单上启用SQLCMD模式,而不是在每次执行后手动执行此操作

在此处输入图片说明

然后使用:connect命令(调整为您的服务器/实例名称)

:connect (local)\SQL2014

create table #foo(x int)

create table #bar(x int)

select *
from #foo
Run Code Online (Sandbox Code Playgroud)

可以多次运行而不会出现问题。消息选项卡显示

正在连接到(本地)\ SQL2014 ...

(0行受影响)

正在从(本地)\ SQL2014断开连接...

  • 我只想提一下,您可以将RichardTheKiwi的SQL存储在文件中(稍作修改也可以删除#表),例如C:\ deleteTempTables.sql,然后使用:r C:\ deleteTempTables调用它.sql`。理查德(Richard)解决方案的唯一优点是,它仅占用一行,并且可以轻松地(无)注释。 (2认同)