首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >在SQL Server中删除全局临时表(##tempTable)

在SQL Server中删除全局临时表(##tempTable)
EN

Stack Overflow用户
提问于 2009-03-27 12:14:19
回答 4查看 47.6K关注 0票数 20

SQL server是否会在给定的不活动时间后自动清除它们,或者我是否需要担心自动清除它们?如果是,如何查询要清除的表列表?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2009-03-27 04:19:19

关闭与SQL Server的连接时,本地临时表将被销毁。正常情况下不需要手动清除它们。如果您维护持久连接或连接池,则可能需要养成在使用后立即删除临时表的习惯。

另一方面,由于全局临时表对给定数据库中的所有用户都可见,因此全局临时表与引用它们的最后一个连接一起被销毁。

票数 16
EN

Stack Overflow用户

发布于 2009-03-27 05:58:05

尽管临时表在连接终止时会被删除,但通常仍认为显式删除临时表是很好的做法,以便绝对确定是否进行了清理。

例如,如果您的平台使用连接池,即连接可能永远不会被删除,那么您的临时表是否因此仍然存在?

为了检查临时表的存在,可以使用下面的语句/ check。

代码语言:javascript
复制
if object_id('tempdb..##temptbl') is not null
begin
    drop table ##temptbl
end
票数 27
EN

Stack Overflow用户

发布于 2011-04-25 22:46:25

在回答问题的第二部分时,要查询要清除的表列表,请尝试以下查询:

代码语言:javascript
复制
SELECT * FROM tempdb..sysobjects

它将列出所有当前的全局临时表

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/688531

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档