删除实例的所有临时表

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了删除实例的所有临时表相关的知识,希望对你有一定的参考价值。

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

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

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

谢谢!

答案

临时表的意思是它们是......临时的。一旦他们超出范围

  • #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)

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

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

另一答案

下面的版本避免了处理'_'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
另一答案

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

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

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

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

:connect (local)SQL2014

create table #foo(x int)

create table #bar(x int)

select *
from #foo

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

连接到(本地) SQL2014 ...

(0行(s)受影响)

断开与(本地) SQL2014的连接...

以上是关于删除实例的所有临时表的主要内容,如果未能解决你的问题,请参考以下文章

MySQL 什么是临时表

获取临时表的结构(如生成 sql 脚本)并清除当前实例的临时表

临时表和游标的使用小总结

在 SQL Developer 中删除临时表

创建本地表和全局表

SQL Server删除库中所有临时表或用户表