我想知道如果有可能有一个删除所有临时表的查询?
我一直在努力使用tempdb.sys.tables来解决问题,但我正在努力格式化name列以使其可以被删除 - 另一个因素使得事情变得有点棘手表名包含一个'_',这意味着做一个替换会变得更加繁琐(对我来说至少!)
我可以使用什么来删除所有临时表(本地或全局),而不必在命名的基础上单独删除它们?
谢谢!
答案 0 :(得分:13)
临时表的意思是它们是......临时的。一旦他们超出范围
查询消失。如果您发现需要手动删除临时表,则需要重新查看使用它们的方式。
对于全局的,这将生成并执行语句以放弃它们。
declare @sql nvarchar(max)
select @sql = isnull(@sql+';', '') + 'drop table ' + quotename(name)
from tempdb..sysobjects
where name like '##%'
exec (@sql)
尽管删除其他会话的[全局]临时表是个坏主意。
对于本地(到此会话)临时表,只需断开连接并重新连接即可。
答案 1 :(得分:12)
以下版本避免了处理'_'
的所有麻烦。我只是想摆脱非全局临时表,因此我的'#[^#]%'
子句中的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
答案 2 :(得分:4)
在存储过程中,当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 ...
的连接